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This publication is the machine reference manual for 
the IBM System/360. It provides a direct, comprehen- 
sive description of the system structure; of the arith- 
metic, logical, branching, status switching, and in- 
put/output operations; and of the interruption system. 

The reader is assumed to have a basic knowledge of 
data processing systems and to have read the IBM 
System/ 360 System Summary, Form A22-6810, which 
describes the system briefly and discusses the input/ 
output devices available. 

For information about the characteristics, functions, 
and features of a specific System/360 model, use the 
functional characteristics manual for that model in 
conjunction with the IBM System/360 Principles of 
Operation. Descriptions of specific input/output de- 
vices used with the System/360 appear in separate 
publications. Publications that relate to the ibm Sys- 
tem/360 Model 20 are described in the IBM Sys- 
tem/360 Model 20 Bibliography, Form A26-3565. 
Other IBM Systems Reference Library publications 
concerning the System/360 are identified and de- 
scribed in the IBM System/360 Bibliography, Form 
A22-6822. 
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IBM System/360 



The IBM System/360 is a solid-state, program com- 
patible, data processing system providing the speed, 
precision, and data manipulating versatility demand- 
ed by the challenge of commerce, science, and in- 
dustry. System/360, with advanced logical design im- 
plemented by microminiature technology, provides a 
new dimension of performance, flexibility, and relia- 
bility. This dimension makes possible a new, more 
eflScient systems approach to all areas of information 
processing, with economy of implementation and ease 
of use. System/360 is a single, coordinated set of new 
data processing equipment intended to replace old 
logical structures with an advanced creative design for 
present and future application. 

The logical design of System/360 permits efficient 
use at several levels of performance with the preser- 
vation of upward and downward program compati- 
bility. In addition, extremely high performance and 
reliability requirements may be met by using the 
multisystem feature to combine several models into 
one multisystem. 



General-Purpose Design 

System/360 is a general-purpose system that may be 
tailored readily for commercial, scientific, communica- 
tions, or control applications. A Standard instruction 
set provides the basic computing function of the sys- 
tem. To this set a decimal feature may be added to 
provide a Commercial instruction set or a floating- 
point feature may be added to provide a Scientific in- 
struction set. When the instructions associated with 
storage protection are added to the commercial and 
scientific features, a Universal instruction set is ob- 
tained. Timer and direct-control features may be used 
with systems to support time-sharing or real-time oper- 
ations, and in teleprocessing applications. 

System/360 is designed to accommodate large quan- 
tities of addressable storage. The markedly increased 
capacities over previous storage are provided by the 
combined use of high-speed storage of medium size 
and large-capacity storage of medium speed. Thus, 
the requirements for both performance and size are 
satisfied in one system by the availability of diff^erent 
types of storage units. Also, the design makes provi- 
sion for development, in the future, of even greater 
storage capacities. 



Another aspect of the general-purpose design of 
System/360 is its standard-interface method for at- 
taching all input/output devices. Future input/output 
devices will also attach to this input/ouput interface 
which is common to all System/360 channels. 

Models of System/360 differ in storage speed, stor- 
age width (the amount of data obtained in each stor- 
age access), register width, and capabilities for proc- 
essing data concurrently with the operation of multi- 
ple input/output devices. Several cpu's permit a wide 
choice in internal performance. The range is such that 
the ratio of internal performances between the largest 
and the smallest model is approximately 50:1 for sci- 
entific computation and 15:1 for commercial process- 
ing. Yet none of these differences affect the logical 
appearance of System/360 to the programmer. 

An individual System/360 is obtained by selecting 
the system components most suited to the applications 
from a wide variety of alternatives in internal per- 
formance, functional ability, and input/output (i/o). 

Compatibility 

All models of System/360 are upward and downward 
compatible; that is, any program gives identical results 
on any model. Compatibility allows for ease in systems 
growth, convenience in systems backup, and simplicity 
in education. The compatibility rule has three limi- 
tations. 

1. The systems facilities used by a program should 
be the same in each case. For example, the optional 
CPU features and the storage capacity, as well as the 
quantity, type, and priority of i/o equipment, should 
be equivalent. 

2. The program should be independent of the re- 
lation of instruction execution times and of i/o data 
rates, access times, and command execution times. 

3. The compatibility rule does not apply to detail 
functions for which neither frequency of occurrence 
nor usefulness of result warrants identical action in 
all models. These functions, all explicitly identified in 
this manual, are concerned with the handling of in- 
valid programs and machine malfunctions. 

System Program 

Interplay of equipment and program is an essential 
consideration in System/360. The system is designed 
to operate with a supervisory program that coordi- 
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nates and executes all i/o instructions, handles excep- 
tional conditions, and supervises scheduling and exe- 
cution of multiple programs. System/360 provides for 
efficient switching from one program to another, as 
well as for the relocation of programs in storage. To 
the problem programmer, the supervisory program 
and the equipment are indistinguishable. 

IBM provides System/360 programs that control and 
schedule the use of cpu facilities, main storage, stor- 
age devices attached to channels, input/output de- 
vices, etc. These programs are designed to control all 
system resources, including programs supplied by the 
customer and by ibm. 



System Alerts 

The interruption system permits the cpu to respond 
automatically to conditions arising outside of the sys- 
em, in i/o units, or in the cpu itself. Interruption 
switches the cpu from one program to another by 
changing not only the instruction address but all es- 
sential machine-status information. 

Protection features permit one program to be pre- 
served when another program erroneously attempts to 
gain access to information in the protected storage 
area. Protection does not cause any loss of perform- 
ance. Storage operations initiated from the cpu, as 
well as those initiated from a channel, are subject to 
the protection procedure. 

Programs are checked for correctness of instructions 
and data as the instructions are executed. This polic- 
ing-action distinguishes and identifies program errors 
and machine errors. Thus, program errors cannot cause 
machine checks: each of these types of error causes a 
different type of interruption. When an interruption 
due to machine malfunction occurs, the information 
necessary to identify the error is recorded automatical- 
ly in a predetermined storage area. This logging of 
pertinent information can be used to assist in the 
analysis of machine faults. Moreover, operator errors 
are reduced by minimizing the number of manual con- 
trols and the need for their use. To reduce accidental 
operator errors, operator consoles are basically i/o de- 
vices that function under control of the system pro- 
gram. 



Multisystem Operation 

Several models of System/360 can be combined into 
one multisystem configuration. Three types of com- 



munication between cpu's are available. Largest in ca- 
pacity, and moderately fast in response, is communi- 
cations by means of a shared i/o device, such as a disk 
file. Faster data transfer may be obtained by direct 
connection between the channels of two individual 
systems. Finally, some models permit sharing of stor- 
age between cpu's, making information exchange: pos- 
sible at storage speeds. These types of communication 
are supplemented by allowing one cpu to be inter- 
rupted by another cpu and by making status informa- 
tion directly available from one cpu to another. 



Input/Output 

Channels provide the data path and control for i/o 
devices as they communicate with the cpu. In general, 
channels operate asynchronously with the cpu and, in 
some cases, a single data path is made up of s<?|veral 
subchannels. When this is the case, the single data 
path is shared by several low-speed devices, such as 
card readers, punches, printers, and terminals, each on 
a separate subchannel. This type of channel is called 
a multiplexor channel. Another type of channel, the se- 
lector channel accommodates higher data rates, but 
can be involved in only one data transfer operation at 
a time. 

In every case, the amount of data that comes into the 
channel in parallel from an i/o device is a byte (i.e., 
eight bits). All channels or subchannels perform the 
same functions and respond to a common set of i/o in- 
structions and commands. 

Each i/o device is connected to one or more chan- 
nels by an i/o interface. This i/o interface allows at- 
tachment of present and future i/o devices without 
alteration of the i/o instruction set or of channel func- 
tions. Control units are used where necessary to match 
the internal connections of the i/o device to the inter- 
face. Flexibility is enhanced by optional access to a 
control unit or device from either of two channels. 



Technology 

System/360 employs solid-logic integrated compo- 
nents, which in themselves provide advanced <}quip- 
ment reliability. These components are smaller than 
previous components, operate faster, and lend them- 
selves to automated fabrication. The design of Sys- 
tem/360, however, is not dependent upon, or limited 
to, any particular type of technology. System/360 is 
free to take continuing advantage of new advances in 
technology. 



System Structure 



The basic structure of a System/360 consists of main 
storage, a central processing unit (cpu), the selector 
and multiplexor channels, and the input/output de- 
vices attached to the channels through control units. 
It is possible for systems to communicate with each 
other by means of shared i/o devices, a channel, or 
shared storage. Figure 1 shows the basic organization 
of a single system. 



Main Storage 

Storage units may be either physically integrated with 
the CPU or constructed as stand-alone units. The stor- 
age cycle speed is not directly related to the internal 
cycling of the cpu, thereby permitting an efficient re- 
lationship of CPU speed to storage width. The physical 
differences in the various main-storage units do not 
affect the logical structure of the system. 

Main storage may be shared by cpu's. Fetching and 
storing of data by the cpu are not affected by any con- 
current i/o data transfer or by reference to the same 
storage location by another cpu. If a cpu and a channel 
concurrently refer to the same storage location, the ac- 
cesses normally are granted in a sequence that assigns 
higher priority to references by channels. If the first 
reference changes the contents of the location, any 
subsequent storage fetches obtain the new contents. 

Instructions that involve fetching and subsequently 
storing of data do not necessarily take the storage 



cycles contiguously, and it is possible for a channel or 
another cpu to take one or more intervening cycles. 
When two cpu's concurrently cause the contents of the 
same location to be updated, such interleaving may 
cause the information stored in one of the accesses to 
be lost or the results to be meaningless. 

For example, if two cpu's attempt to update infor- 
mation at the same location by an instruction that 
causes fetching and subsequently storing of the up- 
dated data at the same location, it is possible for both 
cpu's to fetch the data and subsequently for both cpu's 
to take the store cycles. The change made by the first 
CPU to store the result in such case is lost. Only the in- 
struction TEST AND SET takcs the fetch and store cycles 
without permitting a channel or another cpu to inter- 
leave a cycle. 

The contents of main storage are preserved when 
power is turned on. Turning power off does not affect 
the contents of main storage if the cpu is in the 
stopped state. The contents of the keys in storage as- 
sociated with the protection feature are not necessarily 
preserved when the power for main storage is turned 
off. 



Information Formats 

The system transmits information between main stor- 
age and the cpu in units of eight bits, or a multiple 
of eight bits at a time. Each eight-bit unit of informa- 
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Figure 1. IBM System/360 Basic Logical Structure 
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tion is called a byte, the basic building block of all 
formats. A ninth bit, the parity or check bit, is trans- 
mitted with each byte and carries odd parity on the 
byte. The parity bit cannot be affected by the pro- 
gram; its only purpose is to cause an interruption when 
a parity error is detected. References in this manual to 
the size of data fields and registers exclude the men- 
tion of the associated parity bits. All storage capacities 
are expressed in number of bytes provided, without 
regard to storage width. 

Bytes may be handled separately or grouped to- 
gether in fields. A halfword is a group of two consecu- 
tive bytes and is the basic building block of instruc- 
tions. A word is a group of four consecutive bytes; a 
double word is a field consisting of two words ( Figure 
2). The location of any field or group of bytes is spe- 
cified by the address of its leftmost byte. 

The length of fields is either implied by the oper- 
ation to be performed or stated explicitly as part of 
the instruction. When the length is implied, the in- 
formation is said to have a fixed length, which can be 
either one, two, four, or eight bytes. 

When the length of a field is not implied by the 
operation code, but is stated explicitly, the informa- 
tion is said to have variable field length. Variable- 
length operands are variable in length by increments 
of one byte. 

Within any program format or any fixed-length op- 
erand format, the bits making up the format are con- 
secutively numbered from left to right starting with 
the number 0. 



Byte 



1 1 00000 1 



Halfword 



1 10 10 1 



K 
1 10 1001 Ol 



Word 



I 
11001001 



B 
110000 10 



M 
110 10 10 



11110011 



Figure 2. Sample Information Formats 

Addressing 

Byte locations in storage are consecutively numbered 
starting with 0; each number is considered the ad- 
dress of the corresponding byte. A group of bytes in 
storage is addressed by the leftmost byte of the group. 
The number of bytes in the group is either implied or 



explicitly defined by the operation. The addressing ar- 
rangement uses a 24-bit binary address to accommo- 
date a maximum of 16,777,216 byte addresses. This 
set of main-storage addresses includes some locations 
reserved for special purposes. 

Storage addressing wraps around from the maximum 
byte address, 16,777,215, to address 0. Variable-length 
operands may be located partially in the last and par- 
tially in the first location of storage, and are processed 
without any special indication of crossing the maxi- 
mum address boundary. 

When only a part of the maximum storage capacity 
is available in a given installation, the available stor- 
age is normally contiguously addressable, starting at 
address 0. An addressing exception is recognized 
when any part of an operand is located beyond the 
maximum available capacity of an installation. Except 
for a few instructions, the addressing exception is 
recognized only when the data are actually used and 
not when the operation is completed before using the 
data. The addressing exception causes a program inter- 
ruption. 

In some models main storage may be shared by 
more than one cpu. In that case, the address of a byte 
location is normally the same for each cpu. 

Information Positioning 

Fixed-length fields, such as halfwords and double 
words, must be located in main storage on an integral 
boundary for that unit of information. A boundary is 
called integral for a unit of information when its stor- 
age address is a multiple of the length of the unit in 
bytes. For example, words (four bytes) must be lo- 
cated in storage so that their address is a multiple of 
the number 4. A halfword (two bytes) must have an 
address that is a multiple of the number 2, and double 
words (eight bytes) must have an address that is a 
multiple of the number 8, 

Storage addresses are expressed in binary form. In 
binary, integral boundaries for halfwords, words, and 
double words can be specified only by the binary ad- 
dresses in which one, two, or three of the low-order 
bits, respectively, are zero. (Figure 3). For example, 
the integral boundary for a word is a binary address 
in which the two low-order positions are zero. 

Variable-length fields are not limited to int<3gral 
boundaries, and may start on any byte location. 



Central Processing Unit 

The central processing unit (Figure 4) contains; the 
facilities for addressing main storage, for fetching or 
storing information, for arithmetic and logical proc- 
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Low-order Four Bits of Binary Address 
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Figure 3. Integral Boundaries for Halfwords, Words, and 
Double Words 



essing of data, for sequencing instructions in the de- 
sired order, and for initiating the communication be- 
tween storage and external devices. 

The system control section provides the normal cpu 
control that guides the cpu through the functions 
necessary to execute the instructions. While the 
physical make-up of the control section in the various 
models of the System/360 may be different, the 
logical function remains the same. The result of exe- 
cuting a valid instruction is the same for each model. 

The CPU provides 16 general registers for fixed-point 
operands and four floating-point registers for floating- 



point operands. Implementation of these registers may 
be in special circuitry, in a local storage unit, or in a 
separate area of main storage. In each case, the ad- 
dress and functions of these registers are identical. 

General Registers 

The CPU can address information in 16 general regis- 
ters. The general registers can be used as index regis- 
ters, in address arithmetic and indexing, and as ac- 
cumulators in fixed-point arithmetic and logical oper- 
ations. The registers have a capacity of one word (32 
bits). The general registers are identified by numbers 
0-15 and are specified by a four-bit R field in an in- 
struction (Figure 5). Some instructions provide for 
addressing multiple general registers by having several 
R fields. 

For some operations, two adjacent general registers 
are coupled together, providing a two-word capacity. 
In these operations, the addressed register contains 
the high-order operand bits and must have an even 
address, and the implied register, containing the low- 
order operand bits, has the next higher address. 

Floating-Point Registers 

Four floating-point registers are available for floating- 
point operations. They are identified by the numbers 
0, 2, 4, and 6 ( Figure 5 ) . These floating-point registers 



Storage Address 



MAIN STORAGE 



1- 



Instructions 



Computer 

System 

Control 



Generated 



Address 



I I 



Fixed-Point 
Operations 



Variable- 
Field-Length 
Operations 



Floating-Point 
Operations 



16 
General 
Registers 



Floating-Point Registers 



Figure 4. Basic Concept of Central Processing Unit Functions 



System Structure 9 



R Field 



Reg No. General Registers Floating-Point Registers 



0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 

ion 

1100 
1101 
1110 

1111 





1 

2 

3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 



MpSjZ Blts^Ba 



64 Bits ^^S 



mmMmmm^ 
























\ , 1 






I"": : J 








Ha If word 



Figure 5. General and Floating-Point Registers 



are two words (64 bits) in length and can contain 
either a short ( one word ) or a long ( two words ) float- 
ing-point operand. A short operand occupies the high- 
order bits of a floating-point register. The low-order 
portion of the register is ignored and remains un- 
changed in short-precision arithmetic. The instruction 
operation code determines which type of register 
(general or floating-point) is to be used in an opera 
tion. 



Arithmetic and Logical Unit 

The arithmetic and logical unit can process binary in- 
tegers and floating-point fractions of fixed length, deci- 
mal integers of variable length, and logical information 
of either fixed or variable length. Processing may be in 
parallel or in series; the width of the arithmetic unit, 
the multiplicity of the shifting paths, and the degree; 
of simultaneity in performing the different types of 
arithmetic differ from one CPU to another without af- 
fecting the logical results. 

Arithmetic and logical operations performed by the? 
CPU fall into four classes: fixed-point arithmetic, deci- 
mal arithmetic, floating-point arithmetic, and logical 
operations. These classes differ in the data formats 
used, the registers involved, the operations provided, 
and the way the field length is stated. 



Fixed-Point Arithmetic 

The basic arithmetic operand is the 32-bit fixed-point 
binary word, Sixteen-bit halfword operands may be 
specified in most operations for improved performance 
or storage utilization. See Figure 6. To preserve 



Integer 



Full Word 



Integer 



Figure 6. Fixed-Point Number Formats 



precision, some products and all dividends are 64 bits 
long. 

Because the 32-bit word size readily accom- 
modates a 24-bit address, fixed-point arithmetic can 
be used both for integer operand arithmetic and for 
address arithmetic. This combined usage provides 
economy and permits the entire fixed-point instruction 
set and several logical operations to be used in ad- 
dress computation. Thus, multiplication, shifting, and 
logical manipulation of address components are pos- 
sible. 

Additions, subtractions, multiplications, divisions, 
and comparisons are performed upon one operand in 
a register and another operand either in a register or 
from storage. Multiple-precision operation is made 
convenient by the two's-complement notation and by 
recognition of the carry from one word to another. A 
word in one register or a double word in a pair of 
adjacent registers may be shifted left or right. A pair 
of conversion instructions — convert to binary and 
CONVERT TO DECIMAL — providcs transition between 
decimal and binary radix (number base) without the 
use of tables. Multiple-register loading and storing in- 
structions facilitate subroutine switching. 



Decimal Arithmetic 

Decimal arithmetic lends itself to data processing pro- 
cedures that require few computational steps between 
the source input and the documented output. This type 
of processing is frequently found in commercial appli- 
cations, particularly when use is made of problem- 
oriented languages. Because of the limited number of 
arithmetic operations performed on each item of data, 
radix conversion from decimal to binary and back to 
decimal is not justified, and the use of registers for in- 
termediate results yields no advantage over storage-to- 
storage processing. Hence, decimal arithmetic is pro- 
vided, and both operands and results are located in 
storage. Decimal arithmetic includes addition, subtrac- 
tion, multiplication, division, and comparison. 
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Decimal numbers are treated as signed integers with 
a variable-field-length format from one to 16 bytes 
long. Negative numbers are carried in true form. 

The decimal digits 0-9 are represented in the four- 
bit binary-coded-decimal form by 0000-1001, respec- 
tively (Figure 7). The codes 1010-1111 are not valid 
as digits and are reserved for sign codes; 1011 and 1101 
represent a minus; the other four codes are interpreted 
as plus. The sign codes generated in decimal arithme- 
tic depend upon the character set preferred ( Figure 7 ) . 
When the extended binary-coded-decimal interchange 
code (EBCDIC) is preferred, the codes are 1100 and 
1 1101. When the usascii set, expanded to eight bits, is 
preferred, the codes are 1010 and 1011. The choice 
between the two code sets is determined by a mode 
bit. 

Decimal operands and results are represented by 
four-bit binary-coded-decimal digits packed two to a 
byte. They appear in fields of variable length and are 
accompanied by a sign in the rightmost four bits of the 



Dig 


it Code 


Sign Code 





0000 


+ 1010 


1 


0001 


- 1011 


2 


0010 


+ 1100 


3 


0011 


- 1101 


4 


0100 


+ 1110 


5 


0101 


+ nil 


6 


0110 




7 


0111 





8 1000 

9 1001 

Figure 7. Bit Codes for Digits and Signs 

low-order byte. Operand fields may be located on any 
byte boundary, and may have length up to 31 digits 
and sign. Operands participating in an operation may 
have different lengths. Packing of digits within a byte 
( Figure 8 ) and of variable-length fields within stor- 
age results in eflBcient use of storage, in increased 
arithmetic performance, and in an improved rate of 
data transmission between storage and files. 



High-order Byte 



Low-order Byte 



Digit Digit Digit 



Digit 


Digit 


Digit 


Digit 


Sign 



Figure 8. Packed Decimal Number Format 

Decimal numbers may also appear in a zoned for- 
mat as a subset of the eight-bit alphameric character 
set (Figure 9). This representation is required for 
character-set sensitive i/o devices. A zoned format 
number carries its sign in the leftmost four bits of the 
low-order byte. The zoned format is not used in deci- 
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mal arithmetic operations. Instructions are provided 
for packing and unpacking decimal numbers so that 
they may be changed from the zoned to the packed 
format and vice versa. 



High-order Byte 



Low-order Byte 



Zone 


Digit 


Zone 



Digit 


Zone 


Digit 


Sign 


Digit 



Figure 9. Zoned Decimal Number Format 



Floating-Point Arithmetic 

Floating-point numbers occur in either of two fixed- 
length formats — short or long. These formats differ 
only in the length of the fractions (Figure 10). 



Short Floating-Point Number (One Word) 






S 


Characteristic 


Fraction . 


1 7 8 

Long Floating-Point Number (Double Word) 




31 


S 


Characteristic 


Fraction 


W 





Figure 10. Short and Long Floating-Point Number Formats 

Floating-point operands are either 32 or 64 bits long. 
The short length, equivalent to seven decimal places of 
precision, permits a maximum number of operands to 
be placed in storage and gives the shortest execution 
times. The long length, used when higher precision is 
desired, gives up to 17 decimal places of precision, 
thus eliminating most requirements for double-pre- 
cision arithmetic. 

The operand lengths, being powers of two, permit 
maximum eflBciency in the use of binary addressing 
and in matching the physical word sizes of the differ- 
ent models. Floating-point arithmetic is designed to 
allow easy transition between the two formats. 

The fraction of a floating-point number is expressed 
in hexadecimal (base 16) digits, each consisting of 
four binary bits and having the values 0-15. In the 
short format, the fraction consists of six hexadecimal 
digits occupying bits 8-31. In the long format the 
fraction has 14 hexadecimal digits occupying bits 8-63. 

The radix point of the fraction is assumed to be im- 
mediately to the left of the high-order fraction digit. 
To provide the proper magnitude for the floating- 
point number, the fraction is considered to be mul- 
tiplied by a power of 16. The characteristic portion, 
bits 1-7 of both formats, is used to indicate this power. 
The characteristic is treated as an excess 64 number 
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with a range from —64 through +63, and permits 
representation of decimal numbers with magnitudes 
in the range of 10" '^» to 10^*^. 

Bit position in either format is the sign (S) of the 
fraction. The fraction of negative numbers is carried 
in true form. 

Four 64-bit floating-point registers are provided. 
Arithmetic operations are performed with one oper- 
and in a register and another either in a register or 
from storage. The result, developed in a register, is 
generally of the same length as the operands. The 
availability of several floating-point registers elimi- 
nates much storing and loading of intermediate re- 
sults. 

Logical Operations 

Logical information is handled as fixed- or variable- 
length data. It is subject to such operations as com- 
parison, translation, editing, bit testing, and bit setting. 

When used as a fixed-length operand, logical in- 
formation can consist of either one, four, or eight 
bytes and is processed in the general registers (Fig- 
ure 11). 

A large portion of logical information consists of 
alphabetic or numeric character codes, called alpha- 
meric data, and is used for communication with char- 
acter-set sensitive i/o devices. This information has 
the variable-field-length format and can consist of up 
to 256 bytes (Figure 12). It is processed storage to 
storage, left to right, an eight-bit byte at a time. 

Fixed-Length Logical Operand (One, Four, or Eight Bytes) 
Logical Data 



Figure 11. Fixed-Length Logical Information 



Variable-Length Logical Operand (Up to 256 Bytes) 



Character 


Character 



Character 



Figure 12. Variable-Length Logical Information 

The CPU can handle any eight-bit character set, al- 
though certain restrictions are assumed in the decimal 
arithmetic and editing operations. However, all char- 
acter-set sensitive i/o equipment will assume either 
the extended binary-coded-decimal interchange code 
( EBCDIC) or the USA Standard Code for Information 
Interchange (usascii) extended to eight bits, referred 
to as usASCii-8 in this manual. The numbering con 
vention for the bit positions within a character differ 
for each of the codes. The conventions are as follows: 



EBCDIC 
USASCII-8 



BIT POSITIONS 

01234567 
87654321 



The preferred codes do not have a graphic defined 
for all 256 eight-bit codes. When it is desirable to rep- 
resent all possible bit patterns, a hexadecimal repre- 
sentation may be used instead of the preferred eight- 
bit code. The hexadecimal representation uses one 
graphic for a four-bit code, and therefore, two graph- 
ics for an eight-bit byte. The graphics 0-9 are used 
for codes 0000-1001; the graphics a-f are used for 
codes 1010-1111. The code tables are in Appendix F. 



Program Execution 

The CPU program consists of instructions, index words, 
and control words specifying the operations to be per- 
formed. This information resides in main storage and 
general registers, and may be operated upon as data. 

Instruction Format 

The length of an instruction format can be one, two, 
or three halfwords. It is related to the number of stor- 
age addresses necessary for the operation. An instruc- 
tion consisting of only one halfword causes no refer- 
ence to main storage. A two-halfword instruction pro- 
vides one storage-address specification; a three-half- 
word instruction provides two storage-address specifi- 
cations. All instructions must be located in storage on 
integral boundaries for halfwords. Figure 13 shows 
five basic instruction formats. 

The five basic instruction formats are denoted by 
the format codes rb, rx, rs, si, and ss. The format 
codes express, in general terms, the operation 1o be 
performed, rr denotes a register-to-register operation; 
RX, a register-and-indexed-storage operation; rs, a reg- 
ister-and-storage operation; si, a storage and immedi- 
ate-operand operation; and ss, a storage-to-storage 
operation. An immediate operand is one contained 
within the instruction. 

For purposes of describing the execution of instruc- 
tions, operands are designated as first and second op- 
erands and, in the case of branch-on-index instructions, 
third operands. These names refer to the manner in 
which the operands participate. The operand to which 
a field in an instruction format applies is generally de- 
noted by the number following the code name of the 
field, for example, Ri, Bi, L2, D2. 

In each format, the first instruction halfword con- 
sists of two parts. The first byte contains the oper- 
ation code (op code). The length and format of an 
instruction are specified by the first two bits of the 
operation code. 
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First Halfword 1 
Byte 1 j Byte 2 


Second Halfword 2 


Third Halfword 3 



Register Register 
Operand 1 Operand 2 



Op Code 


•^1 


■^2 



RR Format 



7 8 1112 15 



Register 
Operand 1 



Address 
Operand 2 



Op Code 


■^1 


>^2 


^2 


^2 


7 


8 11 


12 15 16 1920 31 



Register Register Address 

Operand 1 Operand 3 Operand 2 



Op Code 


^1 


^3 


h 


^2 



7 8 1112 15 16 1920 

I I 

I ' 

I Immediate ' 



] Operand | 



Address 
Operand 1 



' Length i 

Operand 1 Operand 2 



Address 
Operand 1 



Op Code 


'2 


^1 


^1 



RX Format 



RS Format 



SI Format 



Address 
Operand 2 



Op Code 


h 


4 


«i 


^1 


h 


^2 



SS Format 



7 8 1112 15 16 1920 



Figure 13. Five Basic Instruction Formats 



INSTRUCTION LENGTH RECORDING 



POSITIONS 


INSTRUCTION 


INSTRUCTION 


(0-1) 


LENGTH 


FORMAT 


00 


One halfword 


RR 


01 


Two halfwords 


RX 


10 


Two halfwords 


RS or SI 


11 


Three halfwords 


SS 



The second byte is used either as two 4-bit fields 
or as a single eight-bit field. This byte can contain the 
following information: 

Four-bit operand register specification (Ri, R2, or 
R3) 

Four-bit index register specification (X2) 

Four-bit mask (Mi) 

Four-bit operand length specification (Li or L2) 

Eight-bit operand length specification (L) 

Eight-bit byte of immediate data (I2) 
In some instructions a four-bit field or the whole sec- 
ond byte of the first halfword is ignored. 

The second and third halfwords always have the 
same format; 

Four-bit base register designator (Bi or B2), fol- 
lowed by a 12-bit displacement (Di or D2). 



Address Generation 

For addressing purposes, operands can be grouped 
in three classes: explicitly addressed operands in main 
storage, immediate operands placed as part of the in- 
struction stream in main storage, and operands lo- 
cated in the general or floating-point registers. 

To permit the ready relocation of program seg- 
ments and to provide for the flexible specifications of 
input, output, and working areas, all instructions re- 
ferring to main storage have been given the capacity 
of employing a full address. 

The address used to refer to main storage is gen- 
erated from the following three binary numbers: 

Base Address (B) is a 24-bit number contained in a 
general register specified by the program in the B 
field of the instruction. The B field is included in 
every address specification. The base address can be 
used as a means of static relocation of programs and 
data. In array-type calculations, it can specify the lo- 
cation of an array and, in record-type processing, it 
can identify the record. The base address provides for 
addressing the entire main storage. The base address 
may also be used for indexing purposes. 
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Index (X) is a 24-bit number contained in a general 
register specified by the program in the X field of the 
instruction. It is included only in the address speci- 
fied by the rx instruction format. The rx format in- 
structions permit double indexing; i.e., the index can 
be used to provide the address of an element within 
an array. 

Displacement (D) is a 12-bit number contained in 
the instruction format. It is included in every address 
computation. The displacement provides for relative 
addressing up to 4095 bytes beyond the element or 
base address. In array-type calculations the displace- 
ment can be used to specify one of many items as- 
sociated with an element. In the processing of records, 
the displacement can be used to identify items within 
a record. 

In forming the address, the base address and index 
are treated as unsigned 24-bit positive binary integers. 
The displacement is similarly treated as a 12-bit posi- 
tive binary integer. The three are added as 24-bit 
binary numbers, ignoring overflow. Since every ad- 
dress includes a base, the sum is always 24 bits long. 
The address bits are numbered 8-31 corresponding to 
the numbering of the base address and index bits in 
the general register. 

The program may have zeros in the base address, 
index, or displacement fields. A zero is used to indi- 
cate the absence of the corresponding address com- 
ponent. A base or index of zero implies that a zero 
quantity is to be used in forming the address, regard- 
less of the contents of general register 0. A displace- 
ment of zero has no special significance. Initialization, 
modification, and testing of base addresses and in- 
dexes can be carried out by fixed-point instructions, 
or by BRANCH and link, branch on count, or branch- 
ON-iNDEx instructions. 

As an aid in describing the logic of the instruction 
format, examples of two instructions and their related 
instruction formats follow. 

RR Format 



Add 


7 


9 



Execution of the add instruction adds the contents of 
general register 9 to the contents of general register 
7 and the sum of the addition is placed in general 
register 7. 



RX Format 



Store 


3 


10 


14 


300 



Execution of the store instruction stores the contents 
of general register 3 at a main-storage location ad- 
dressed by the sum of 300 and the low-order 24 bits 
of general registers 14 and 10. 

Sequential Instruction Execution 

Normally, the operation of the cpu is controlled by 
instructions taken in sequence. An instruction is 
fetched from a location specified by the instruction 
address in the current psw. The instruction address is 
then increased by the number of bytes in the instruc- 
tion fetched to address the next instruction in se- 
quence. The instruction is then executed and the same 
steps are repeated using the new value of the instruc- 
tion address. 

Conceptually, all halfwords of an instruction are 
fetched from storage after the preceding operation is 
completed and before execution of the current oper- 
ation, even though physical storage word size and 
overlap of instruction execution with storage access 
may cause actual instruction fetching to be different. 
Thus, it is possible to modify an instruction in storage 
by the immediately preceding instruction. 

A change from sequential operation may be caused 
by branching, status switching, interruptions, or man- 
ual intervention. 

Branching 

The normal sequential execution of instructions is 
changed when reference is made to a subroutine, when 
a two-way choice is encountered, or when a segment 
of coding, such as a loop, is to be repeated. All these 
tasks can be accomplished with branching instruc- 
tions. Provision is made for subroutine linkage, permit- 
ting not only the introduction of a new instruction 
address but also the preservation of the return address 
and associated information. 

Decision-making is generally and symmetrically 
provided by the branch on condition instruction. 
This instruction inspects a two-bit condition code that 
reflects the result of a majority of the arithmetic, logi- 
cal, and i/o operations. Each of these operations can 
set the code in any one of four states, and the con- 
ditional branch can specify any selection of these four 
states as the criterion for branching. For example, the 
condition code reflects such conditions as nonzero, 
first operand high, equal, overflow, channel busy, zero, 
etc. Once set, the condition code remains unchanged 
until modified by an instruction that reflects a dif- 
ferent condition code. 

The two bits of the condition code provide for lour 
possible condition code settings: 0, 1, 2, and 3. The 
specific meaning of any setting is significant only to 
the operation setting the condition code. 
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Loop control can be performed by the conditional 
branch when it tests the outcome of address arith- 
metic and counting operations. For some particularly 
frequent combinations of arithmetic and tests, the in- 
structions BRANCH ON COUNT and BRANCH ON INDEX are 
provided. These branches, being specialized, provide 
increased performance for these tasks. 

Program Status Word 

A double word, the program status word (psw), con- 
tains the information required for proper program 
execution. The psw includes the instruction address, 
condition code, and other fields to be discussed. In 
general, the psw is used to control instruction se- 
quencing and to hold and indicate the status of the 
system in relation to the program currently being exe- 
cuted. The active or controlling psw is called the "cur- 
rent PSW." By storing the current psw during an inter- 
ruption, the status of the cpu can be preserved for 
subsequent inspection. By loading a new psw or part 
of a psw, the state of the cpu can be initialized or 
changed. Figure 14 shows the psw format. 



System Mask 


Key 


AMWP 


Interruption Code 



7 8 11 12 15 16 



ILC 


CC 


Program 
Mask 


Instruction Address 



32 33 34 33 34 39 40 




63 


0-7 


System mask 


14 


Wait state (W) 





Channel mask 


15 


Problem state (P) 


1 


Channel 1 mask 


16-31 


Interruption code 


2 


Channel 2 mask 


32-33 


Instruction Length code (ILC) 


3 


Channel 3 mask 


34-35 


Condition code (CC) 


4 


Channel 4 mask 


36-39 


Program mask 


5 


Channel 5 mask 


36 


Fixed-point overflow mask 


6 


Channel 6 mask 


37 


Decimal overflow mask 


7 


External mask 


38 


Exponent underflow mask 


3-11 


Protection key 


39 


Significance mask 


12 


ASCII (A) 


40-63 


Instruction address 


13 


Machine-check mask (M) 







• Figure 14. Program Status Word Format 

Interruption 

The interruption system permits the cpu to change 
state as a result of conditions external to the system, 
in input/output (i/o) units, or in the cpu itself. Five 
classes of interruption conditions are possible: i/o, 
program, supervisor call, external, and machine check. 
Each class has two related psw's called "old" and 
"new" in unique main-storage locations (Figure 15). 
In all classes, an interruption involves merely storing 
the current psw in its "old" position and making the 
PSW at the "new" position the current psw. The "old" 
PSW holds all necessary status information of the sys- 
tem existing at the time of the interruption. If, at the 
conclusion of the interruption routine, there is an in- 
struction to make the old psw the current psw, the 



system is restored to i:he state prior to the interruption 
and the interrupted routine continues. 



Address 



Length 



Purpose 






0000 


0000 


double 


word 


Initial program loading PSW 


8 


0000 


1000 


double 


word 


Initial program loading CCWl 


16 


0001 


0000 


double 


word 


Initial program loading CCW2 


24 


0001 


1000 


double 


word 


External old PSW 


32 


0010 


0000 


double 


word 


Supervisor call old PSW 


40 


0010 


1000 


double 


word 


Program old PSW 


48 


0011 


oobo 


double 


word 


Machine check old PSW 


56 


0011 


1000 


double 


word 


Input/output old PSW 


64 


0100 


0000 


double 


word 


Channel status word 


72 


0100 


1000 


word 




Channel address word 


76 


0100 


1100 


word 




Unused 


80 


0101 


0000 


word 




Timer 


84 


0101 


0100 


word 




Unused 


88 


0101 


1000 


double 


word 


External new PSW 


96 


Olio 


0000 


double 


word 


Supervisor call new PSW 


104 


Olio 


1000 


double 


word 


Program new PSW 


112 


0111 


0000 


double 


word 


Machine check new PSW 


120 


0111 


1000 


double 


word 


Input/output new PSW 


128 


1000 


0000 






Diagnostic scan-out area* 



* The size of the diagnostic scan-out area depends upon the 
particular system's CPU and I/O channels. 



Figure 15. Permanent Storage Assignments 

Interruptions are taken only when the cpu is inter- 
ruptable for the interruption source. The system mask, 
program mask, and machine check mask bits in the 
psw may be used to mask certain interruptions. When 
masked off, an interruption either remains pending or 
is ignored. The system mask may keep i/o and ex- 
ternal interruptions pending, the program mask may 
cause four of the 15 program interruptions to be ig- 
nored, and the machine-check mask may cause ma- 
chine-check interruptions to remain pending. Other 
interruptions cannot be masked off. 

An interruption always takes place after one in- 
struction execution is finished and before a new in- 
struction execution is started. However, the occurrence 
of an interruption may affect the execution of the cur- 
rent instruction. To permit proper programmed action 
following an interruption, the cause of the interrup- 
tion is identified and provision is made to locate the 
last executed instruction. 

Input/Output Interruption 

An i/o interruption provides a means by which the 
CPU responds to conditions in the channels and i/o 
units. 

An i/o interruption can occur only when the mask 
bit associated with the channel is set to one. The ad- 
dress of the channel and i/o unit involved are recorded 
in bits 16-31 of the old psw. Further information con- 
cerning the i/o action is preserved in the channel sta- 
tus word (csw) that is stored during the interruption. 
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Program Interruption 

Unusual conditions encountered in a program create 
program interruptions. These conditions include in- 
correct operands and operand specifications, as well 
as exceptional results. The interruption code identifies 
the interruption cause. Figure 16 shows the different 
causes that may occur. 



Interruption 
Code 



00000001 
00000010 
0000001 1 
00000100 
00000101 
00000110 
00000111 

8 00001000 

9 00001001 

10 00001010 

11 00001011 

12 00001100 

13 00001101 

14 00001110 

15 00001111 



Program Interruption 
Cause 

Operation 

Privileged operation 

Execute 

Protection 

Addressing 

Specification 

Data 

Fixed-point overflow 

Fixed-point divide 

Decimal overflow 

Decimal divide 

Exponent overflow 

Exponent underflow 

Significance 

Floating-point divide 



Figure 16. Interruption Code for Program Interruption 

Supervisor-Call Interruption 

This interruption occurs as a result of execution of the 
instruction supervisor call. Eight bits from the in- 
struction format are placed in the interruption code 
of the old psw, permitting an identification to be asso- 
ciated with the interruptions. A major use for the in- 
struction SUPERVISOR CALL IS to switch from the prob- 
lem-state to the supervisor state. This interruption may 
also be used for other modes of status-switching. 

External Interruption 

The external interruption provides the means by 
which the cpu responds to signals from the interrup- 
tion key on the system control panel, the timer, and 
the external signals of the direct control feature. 

An external interruption can occur only when sys- 
tem mask bit 7 in the psw is one. 

The source of the interruption is identified by the 
interruption code in bits 24-31 of the psw (Figure 17). 
Bits 16-23 of the interruption code are made zero. 



nterruption 


External 




Code Bit 


Interruption Cause 


Mask Bit 


24 


Timer 


7 


25 


Interrupt key 


7 


26 


External signal 2 


7 


27 


External signal 3 


7 


28 


External signal 4 


7 


29 


External signal 5 


7 


30 


External signal 6 


7 


31 


External signal 7 


7 



Figure 17. Interruption Code for External Interruption 



Machine-Check Interruption 

The occurrence of a machine check (if not masked 
ofl^) terminates the current instruction, initiates a diag- 
nostic procedure, and subsequently causes the ma- 
chine-check interruption. A machine check cannot be 
caused by invalid data or instructions. The diagnostic 
scan is performed into the scan area starting at lo- 
cation 128. Proper execution of these steps depends 
on the nature of the machine check. 

Priority of Interruptions 

During execution of an instruction, several interrup- 
tion requests may occur. Simultaneous interruption re- 
quests are honored in the following predetermined 
order: 

Machine Check 

Program or Supervisor Call 

External 

Input/Output 
The program and supervisor-call interruptions are 
mutually exclusive and cannot occur at the same time. 
When more than one interruption cause requests 
service, the action consists of storing the old psw and 
fetching the new psw belonging to the interruption 
which is taken first. This new psw subsequently is 
stored without any instruction execution and the next 
interruption psw is fetched. This process continues 
until no more interruptions are to be serviced. When 
the last interruption request has been serviced, in- 
struction execution is resumed using the psw last 
fetched. The order of execution of the interruption 
subroutines is, therefore, the reverse of the order in 
which the psw's are fetched. 

Thus, the most important interruptions — i/o, ex- 
ternal, program or supervisor call — are actually serv- 
iced first. Machine check, when it occurs, does not al- 
low any other interruptions to be taken. 

Program States 

Over-all cpu status is determined by four types of pro- 
gram-state alternatives, each of which can be changed 
independently to its opposite and most of which are 
indicated by a bit or bits in the psw. The program- 
state alternatives are named stopped or operating, 
running or waiting, masked or interruptible, and sup- 
ervisor or problem state. These states differ in the way 
they affect the cpu functions and the manner in which 
their status is indicated and switched. All program 
states are independent of each other in their functions, 
indication, and status-switching. 

Stopped or Operating States: The stopped state is 
entered and left by manual procedure. Instructions are 
not executed, interruptions are not accepted, and the 
timer is not updated. In the operating state, the cpu 



16 



is capable of executing instructions and being inter- 
rupted. 

Running or Waiting State: In the running state, in- 
struction fetching and execution proceed in the normal 
manner. The wait state is normally entered by the 
program to await an interruption, for example, an i/o 
interruption or operator intervention from the console. 
In the wait state, no instructions are processed, the 
timer is updated, and i/o and external interruptions 
are accepted, unless masked. Running or waiting state 
is determined by the setting of bit 14 in the psw. 

Masked or Interruptible State: The cpu may be in- 
terruptible or masked for i/o, external, machine-check, 
and some program interruptions. When the cpu is in- 
terruptible for a class of interruptions, these interrup- 
tions are accepted. When the cpu is masked, the i/o, 
external, and machine-check interruptions remain 
pending, whereas program interruptions are ignored. 
The interruptible states of the cpu are changed by 
changing the mask bits of the psw. 

Supervisor or Problem State: In the problem state, 
all i/o instructions and a group of control instructions 
are invalid. In the supervisor state, all instructions 
are valid. The choice of problem or supervisor state is 
determined by bit 15 of the psw. 



Protection Features 

Two protection features are available. These features 
make it possible to protect the contents of main stor- 
age from destruction or misuse. When the store-protec- 
tion feature is installed, attempts to modify storage are 
monitored. The addition of the fetch-protection feature 
to the store-protection feature provides for monitoring 
of all accesses to storage. 

Protection is achieved by dividing main storage into 
blocks of 2,048 bytes, and by associating a five-bit key 
with each block. Two instructions — set storage key 
and insert storage key — are provided for assigning 
and inspecting the code in a key. The same code may 
be used in many keys. 

A user's right of access to storage is identified by a 
four-bit protection key. For references caused by the 
CPU, the protection key in the current psw is used; ac- 
cesses by channels are controlled by the protection key 
assigned to the associated i/o operation. 

When protection applies to a main-storage reference, 
the key in storage is compared with the protection key 
associated with the reference. Access to the location, 
for both operands and instructions, is granted only 
when the two keys match. The keys are said to match 
when the four high-order bits of the key in storage are 
equal to the protection key or when the protection key 



is zero. When store-and-fetch protection is installed, 
the low-order bit of the key in storage is used to speci- 
fy whether or not fetching is to be monitored. 

When a protection mismatch is detected, the con- 
tent of the protected main-storage location remains un- 
altered. A protection violation due to a cpu reference 
causes the instruction to be suppressed or terminated 
and program execution to be altered by an interrup- 
tion. A violation due to an i/o operation causes the i/o 
operation to be terminated, with the protection mis- 
match indicated in the channel status word stored at 
the end of an i/o operation. 



Timer Feature 

The timer is provided as an interval timer and may 
be programmed to maintain the time of day. The 
timer consists of a full word in main-storage location 
80. The timer word is counted down at a rate of 50 
or 60 cycles per second, depending on line frequency. 
The timer word is treated as a signed integer follow- 
ing the rules of fixed-point arithmetic. An external in- 
terruption condition is signaled when the value of the 
timer word goes from positive to negative. The full 
cycle time of the timer is 15.5 hours. 

An updated timer value is available at the end of 
each instruction execution but is not updated in the 
stopped state. The timer is changed by addressing 
storage location 80. As an interval timer, the timer is 
used to measure elapsed time over relatively short in- 
tervals. It can be set to any value at any time. 



Direct Control Feature 

The direct control feature provides two instructions, 
READ DIRECT and wTiiTE DIRECT, and six external inter- 
ruption lines. The read and write instructions provide 
for the transfer of a single byte of information be- 
tween an external device and the main storage of the 
system. It is usually most desirable to use the data 
channels of the system to handle the transfer of any 
volume of information and use the direct data control 
feature to pass controlling and synchronizing informa- 
tion between the cpu and special external devices. 

Each of the six external signal lines, when pulsed, 
sets up the conditions for an external interruption. 



Multisystem Operation 

The design of System/360 permits communication be- 
tween individual cpu's at several transmission rates. 
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The communication is possible through shared con- 
trol units, through a channel-to-channel adapter, and 
through shared storage. Interconnection of cpu's is 
further enhanced by the direct control feature (de- 
scribed in the previous section), which can be used to 
signal from one cpu to another, and by facilities for 
direct address relocation, malfunction indication, and 
external cpu initialization. 

The relocation procedure applies to the first 4,096 
bytes of storage. This area contains all permanent 
storage assignments and, generally, has special signifi- 
cance to supervisory programs. The relocation is ac- 
complished by inserting a 12-bit prefix in each address 
which has the high-order 12 bits set to zero and hence, 
pertains to location 0-4095. Two manually set prefixes 
are available to permit the use of an alternative area 
when storage malfunction occurs. The choice between 
the prefixes is determined by a prefix trigger set dur- 
ing initial program loading. 

To alert one cpu to the possible malfunction of an- 
other CPU, a machine check-out signal is provided, 
which can serve as an external interruption to another 

CPU. 

Finally, provision is made for starting one cpu by a 
signal from another cpu. 



Input and Output 

The following information is introductory in nature. 
For thorough definition of the input/output system, 
see "Input/Output Operations." 



Input/Output Devices and Control Units 

Input/output operations involve the transfer of infor- 
mation to or from main storage and an i/o device. 
Input/output devices include such equipment as card 
readers and punches, magnetic tape units, disk storage, 
drum storage, typewriter-keyboard devices, printers, 
teleprocessing devices, and process control equipment. 
Many i/o devices function with an external docu- 
ment, such as a punched card or a reel of magnetic 
tape. Some i/o devices handle only electrical signals, 
such as those found in process-control networks. In 
either case, i/o device operation is regulated by a 
control unit. The control-unit function may be housed 
with the i/o device, as is the case with a printer, or a 
separate control unit may be used. In all cases, the 
control-unit function provides the logical and buffer- 
ing capabilities necessary to operate the associated 



i/o device. From the programming point of view, 
most control-unit functions merge with i/o device 
functions. 



input/ Output Interface 

All communication between the control unit and the 
channel takes place over a connection called the i/o 
interface. The i/o interface provides an information 
format and control signal sequences that are independ- 
ent of the type of control unit and channel and provide 
a uniform means of attaching and controlling various 
types of i/o devices. 



Channels 

The channel controls transfer of data between i/o de- 
vices and main storage. It connects with the cpu and 
main storage and, via the i/o interface, with control 
units. The channel relieves the cpu of the burden of 
communicating directly with i/o devices and permits 
data processing to proceed concurrently with i/o 
operations. 

A channel may be an independent unit, complete 
with necessary logical and storage capabilities, or it 
may time-share cpu facilities and be physically inte- 
grated with the CPU. In either case, channel functions 
are identical. Channels may be implemented, however, 
to have different maximum data transfer capabilities. 

The System/360 has two types of channels: multi- 
plexor and selector. The channel facility necessary to 
sustain an operation with an i/o device is called a 
subchannel. The selector channel has one subchannel; 
the multiplexor channel has multiple subchannels. 

Channels have two modes of operation: burst and 
multiplex. 

In the burst mode, the data transfer facilities of the 
channel are monopolized for the duration of transfer 
of a burst of data. Other devices attached to the 
channel cannot transfer data until the burst ceases. 
The selector channel functions only in the burst mode. 

The multiplexor channel functions in either the 
burst mode or in the multiplex mode. In the multiplex 
mode, the multiplexor channel can sustain concurrent 
i/o operations on several subchannels. Bytes of data 
associated with different i/o devices are interleaved 
and routed to or from the desired locations in main 
storage. The i/o interface is time-shared by a number 
of concurrently operating i/o devices, each of which 
uses its own subchannel. 

Some i/o devices can operate only in burst mode. 
Other i/o devices have a manual switch in the control 
imit that may be set to a burst-mode or to a multiplex- 
mode position, when attached to a multiplexor chan- 
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nel. When attached to a selector channel, an i/o de- 
vice can operate only in burst mode. 

Input/ Output Instructions 

The System/360 uses only four i/o instructions: 
STABT i/o 
TEST l/o 
HALT l/o 
TEST CHANNEL 

Input/output instructions can be executed only 
while the cpu is in the supervisor state. 

Start I/O 

The START i/o instruction is used to initiate an i/o 
operation. The address part of the instruction specifies 
the channel and i/o device. 

Test I/O 

Execution of the test i/o instruction sets the con- 
dition code in the psw to indicate the state of the ad- 
dressed channel, subchannel, and i/o device, and may 
cause a csw to be stored. The instruction may be used 
to clear i/o interruption conditions, selectively by 
device. 

Halt I/O 

The HALT i/o instruction terminates a channel opera- 
tion. 

Test Channel 

Execution of the test channel instruction sets the 
condition code in the psw^ to indicate the state of the 
channel addressed by the instruction. The resulting 
condition code indicates one of the following: chan- 
nel available, interruption condition in channel, chan- 
nel working, or channel not operational. 

Input/ Output Operation Initiation 

An i/o operation is initiated by a start i/o instruction. 
If the necessary channel and device facilities are avail- 
able, START i/o is accepted and the cpu continues its 
program. The channel independently governs the i/o 
device specified by the instruction. 

Channel Address Word 

Successful execution of start i/o causes the channel 
to fetch a channel address word (caw) from the 
main-storage location 72. The caw specifies the byte 
location in main storage where the channel program 
begins. 

Figure 18 shows the format for the caw. Bits 0-3 
specify the storage-protection key that will govern the 
i/o operation. Bits 4-7 must contain zeros. Bits 8-31 
specify the location of the first channel command 
word (ccw). 



Key 



Command Address 



3 4 7 8 31 

Figure 18. Channel Address Word Format 

Channel Command Word 

The byte location specified by the caw is the first of 

eight bytes of information that the channel fetches 

from main storage. ITiese 64 bits of information are 

called a channel command word (ccw). Only the 

START i/o instruction may cause the channel to fetch 

ccw's. 

One or more ccw's make up the channel program 
that directs channel operations. 

A channel command word can specify one of six 
commands: 

Read 

Write 

Read Backward 

Control 

Sense 

Transfer In Channel 

If more than one ccw is to be fetched, the ccw's are 
to be fetched sequentially, except when transfer in 
channel is encountered. Figure 19 shows the format 
for ccw's. 



Command 
Code 


Data Address 



Flags 


000 


WMB. 


Count 



The command code specifies the operation to be performed (read, write, 
rewind, etc.). 

The data address specifies the first byte location in main storage for a 
data transfer type of operation. 

The flag bits may specify chaining to another CCW, suppression of a 
possible incorrect-length indication, etc. 

The count specifies the number of bytes for a data transfer operation. 

Figure 19. Channel Command Word Format 



Input/Output Commands 

Read 

The read command causes data to be read from the 
selected i/o device and defines the area in main 
storage to be used. 

Write 

The write command causes a write operation on the 
selected i/o device and defines the data in main stor- 
age to be written. 
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Read Backward 

The read-backward command causes a read operation 
in which the characters are read from the external 
document in reverse order by the i/o device. Bytes 
read backward are placed in descending main storage 
locations. 

Control 

The control command contains information used to 
control the selected i/o device. This control informa- 
tion is called an order. Order information may be en- 
tirely contained in the command code, or the control 
command may provide a data address and byte count 
for additional order information in main storage to be 
fetched by the channel. Also, a control command may 
specify information in main storage such as the address 
of a particular disk storage track. 

Orders are peculiar to the particular i/o device in 
use; orders can specify such functions as rewinding a 
tape unit, loading a tape cartridge, or line skipping on 
a printer. A control command may cause mechanical 
motion by an i/o device, or it may specify a function 
altogether electronic in nature, such as setting the re- 
cording density for a tape unit operation. 

The general relationship of i/o instructions, com- 
mands, and orders is shown in Figure 20. 



CPU 

(Decodes 

I/O 

Instructions) 




Channels 

(Decodes 
Commands) 




Control Unit 

and/or 
I/O Device 

(Decodes 
Orders) 







Figure 20. Relationship of I/O Instructions, Commands, and 
Orders 



Sense 

The sense command specifies the beginning main 
storage location to which sense information is trans- 
ferred from the selected control unit. One or more 
bytes of sense data may be specified, depending upon 
the type of i/o device. The sense data provides de- 
tailed information concerning the selected i/o device, 
such as a stacker-full condition of a card reader or a 
file-protected condition of a reel of magnetic tape on a 
tape unit. Sense data have significance peculiar to 
the type of i/o device involved. 

Transfer In Channel 

The transfer-in-channel (tic) command specifies the 
location of the next cow to be fetched and used by the 
channel. The tic command is used whenever the pro- 
grammer wants to specify a ccw that is not located at 



the next higher double word location in main storage. 
The TIC command permits a programmer to cause exe- 
cution of any ccw, including a ccw immediately pre- 
ceding a TIC command, except that the channel will not 
permit a tic command to specify execution of another 
TIC command. Also, the caw may not address a tic 
command. 

Input/ Output Termination 

Input/output operations terminate with the device and 
channel signaling end of operation and a request for an 
i/o interruption. 

A command can be rejected during an attempt to 
execute a start i/o, however, by a busy condition, by 
a channel programming error, etc. The condition code 
set in the psw by an unsuccessful start i/o instruction 
will indicate one of the following: that a channel status 
word (csw) has been stored to detail the conditions 
that precluded initiation of the i/o operation, that the 
equipment is busy, or that the addressed equipment is 
not operational. 

Channel Status Word 

The channel status word (csw) provides information 
about the termination of an i/o operation. It can be 
formed or reformed by start i/o, test i/o, halt i/o, 
or by an i/o interruption. The instruction test cecan- 
NEL does not affect the csw. Figure 21 shows the csw 
format. 



Key 


0000 


Command Address 


34 7 8 


31 


Status 


Count 



The key field contains the protection key used in the last operation. 

The command address specifies the location plus 8 of the last CCW 
used. 

The status field contains a unit status byte and a channel status byte. 
The unit status byte may indicate one or more conditions, such as control 
unit end, device end, busy, etc. The channel status byte may indicate a 
channel programming error, a channel data check, etc. 

The count field specifies the residual count of the last CCW used. 

Figure 21. Channel Status Word Format 



Input/Output Interruptions 

Input/output interruptions are caused by termination 
of an i/o operation or by operator intervention at the 
i/o device. An i/o interruption stores the current psw 
in the i/o old psw location, and places the i/o new 
PSW in control of the system. The i/o new psw, when 
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made current by an i/o interruption, may cause cpu 
interrogation of the channel status word, or take what- 
ever action is considered appropriate by the pro- 
grammer. 

An i/o interruption request may be initiated by an 
i/o interruption condition in a device, a control unit, 
or a channel. When a channel has multiple i/o inter- 
ruption requests pending, it establishes a priority se- 
quence for them before initiating an i/o interruption 
request to the cpu. Conditions responsible for i/o inter- 
ruption requests remain pending in the i/o devices or 
channels until they are accepted by the cpu. 

Basic Procedure for a Data-Transfer Operation 

A START i/o instruction is used to initiate data transfer 
to or from an i/o device. To perform such an opera- 
tion, it is necessary for the programmer to: 

1. Establish a channel command word (ccw) or a 
list of ccw's in main storage. 

2. Load the channel address word (caw) with the 
address of the first byte of the first ccw in the channel 
program. 

3. Load the channel and device address in the start 
i/o instruction to be used for the operation. 

4. Set the system mask to disable all channels for i/o 
interruptions. 

5. Issue the start i/o instruction. 

6. Test the condition code established in the current 
psw by termination of the start i/o. 

Condition code indicates that the i/o operation 
has been initiated and that the channel is proceeding 
with its execution. If an i/o interruption is desired 
upon termination of the operation, the pertinent chan- 
nel mask bit must be set to one (an appropriate i/o 
new PSW must have been established previously ) . 

Condition code 1 indicates that a channel status 
word (csw) has been stored; its status bytes should be 
examined to determine why the desired operation was 
not initiated. 

Condition code 2 indicates that the channel or sub- 
channel addressed by the start i/o instruction was 
found to be busy with a previously initiated operation. 
If an i/o interruption from the operation already in 
progress is desired, the channel mask bit must be set 
to one. 

Condition code 3 indicates that the addressed equip- 
ment is not operational; a message to the operator may 
be initiated. 

Between the time a start i/o instruction is decoded 
by the cpu, and the time the cpu is released by the 
channel with condition code set in the current psw, 
the channel performs many functions. The caw must 
be fetched, the first ccw must be fetched, the caw and 
ccw must be tested for validity, etc. After a start i/o 



results in condition code 0, the operation continues un- 
til terminated. Termination of an i/o operation causes 
a request for an i/o interruption. Some of the relation- 
ships of CPU and channel functions are illustrated in 
Figure 22. The example covers the time span from 
initation of a start i/o instruction to a resulting i/o 
interruption. 

The example illustrates a simple read operation. The 
START i/o used in Figure 22 addresses an ibm 2403 
Magnetic Tape Unit and Control. The caw addresses 
a ccw specifying a read operation. The ccw does not, 
however, specify command chaining or data chaining. 
Therefore, the single read ccw constitutes the entire 
channel program for the example. 

The example is limited to the start i/o considera- 
tions shown in Figure 22; a successful read operation 
is assumed, and many machine functions, such as chan- 
nel testing of caw and ccw for validity, device selec- 
tion, etc., are not represented. Similarly, other system 
operations, such as concurrent i/o operations, multi- 
programming, etc., are not considered. 

The purpose of this part of the manual has been to 
illustrate a data transfer operation, with major empha- 
sis given to the point-in -time relationships of cpu and 
channel functions. The start i/o example provided 
does not purport to show how data-transfer program- 
ming should be done; a programmer familiar with the 
i/o system may generate considerably more compre- 
hensive i/o routines. 

See the "Input/Output Operations" section of this 
manual for thorough, detailed description of i/o opera- 
tions. 

System Control Panel 

The system control panel provides the switches, keys, 
and lights necessary to operate and control the system. 
The need for operator manipulation of manual con- 
trols is held to a minimum by the system design and 
the governing supervisory program. The result is few- 
er and less serious operator errors. 

System Control Panel Functions 

The main functions provided by the system control 
panel are the ability to: reset the system; store and 
display information in main storage, in registers, and 
in the PSW; and load initial program information. 

System Reset 

The system-reset function resets the cpu, the channels, 
and on-line control units and i/o devices. In general, 
the system is placed in such a state that processing 
can be initiated without the occurrence of machine 
checks, except those caused by subsequent machine 
malfunction. 
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CPU Instruction Execution t-«— START I/O-* 



CPU Program 
— Resumed 



System Masi<: Bit for Addressed 
Channel 

CAW Fetch by Channel 

CCW Fetch by Channel 

Condition Code Set in 
Current PSW 

Operation Executed by Device 

Channel End 

Device End 

I/O Interruption 

CSW Stored 



■ Is Zero 



-*-f<- 



IsOne- 



n 



n 



A 



•CPU released by channel; next sequential instruction is 
executed. (The BRANCH ON CONDITION instruction 
should now be used to branch on the condition code just 
established in the current PSW.) 



rl/O new 
of next i 
instructi( 




I/O new PSW becomes the current PSW; it specifier address 
nstruction to be executed. (TEST UNDER MASK 
ons should be used to examine the status field in 

the CSW just stored.) 



-^s- 



-^v- 



. . Is Zero. A mask of zero inhibits I/O interruptions; a 
mask of one permits them. 

CAW, fetched from location 72, specifies address of first 
CCW. 

CCW provides read command code, storage address for 
first byte, and number of bytes to be read. 

Operation specified by first CCW initiated successfully. 

Read operation specified by first CCW is performed. 

Completion of data-transfer part of operation is indicated 
by setting channel-end status bit to one. 

Completion of operation at device is indicated by setting 
device-end status bit to one. 

jl[__ Termination of operation causes I/O interruption; I/O 
new PSW is made current PSW. 

Ijl Status transferred from channel to CSW (location 64); 
unit status byte contains device-end and channel-end 
bits set to one. 



S Timing relationships shown here are only relative. The purpose of this chart is limited to illustration of the relationship of CPU and channel actions; this 
chart is not intended to illustrate signal lines, timing pulses, voltage levels, etc. 

* Dotted lines link concurrent actions. 

t Channel end and device end are concurrent for tape reod or write operations, but other devices or operations cause channel-end and device-end signals 
to be separated by time, which may result in two I/O interruptions. 



SIO: 


START I/O 


CAW: 


Channel Address Word 


CCW: 


Channel Command Word 


CSW: 


Channel Status Word 


PSW: 


Program Status Word 



Figure 22. Basic Timing Chart for IBM 2403 Tape Read Operation 



Store and Display 

The store-and-display function permits manual inter- 
vention in the progress of a program. The function 
may be provided by a supervisory program in con- 
junction with proper i/o equipment and the interrupt 
key. Or, the system-control-panel facilities may be 
used to place the cpu in the stopped state, and then 
to store and display information in main storage, in 
general and floating-point registers, and in the instruc- 
tion-address portion of the PSW. 

Initial Program Loading 

The initial-program-loading (ipl) procedure is used 
to begin or renew system operation. The load key is 
pressed after an input device is selected with the load- 



unit switches. This causes a read operation at the 
selected input device. Six words of information are 
read into main storage and may be used for reading 
more information into any part of main storage. Upon 
completion of the ipl read operation, the double word 
from location is made the current psw for subsequ{3nt 
control of the system. 

The system controls are divided into three sections: 
operator control, operator intervention, and customer 
engineering control. 

Operator Control Section 

This section of the system control panel contains the 
operator controls required when the cpu is operating 
under supervisory program control. 
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The main functions provided are the control and 
indication of power, the indication of system status, 
and operator-to-machine communication. These in- 
clude: 

Emergency power-ofiF pull switch 

Power-on back-lighted key 

Power-off key 

Interrupt key 

Wait light 

Manual light 

System light 

Test light 

Load light 

Load-unit switches 

Load key 

Operator Intervention Section 

This section of the system control panel provides 
controls required for operator intervention into normal 
programmed operation. These include: 



System reset key 

Stop key 

Start key 

Rate switch (single cycle or normal processing) 

Storage-select switches 

Address switches 

Data switches 

Store key 

Display key 

Set IC key 

Address compare switches 



Customer Engineering Section 

This section of the system control panel provides the 
controls intended only for customer engineering use. 
Customer engineering controls are also available on 
some storage, channel, and control-unit equipment. 
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Fixed-Point Arithmetic 



The fixed-point instruction set performs binary arith- 
metic on operands serving as addresses, index quanti- 
ties, and counts, as well as fixed-point data. In general, 
both operands are signed and 32 bits long. Negative 
quantities are held in two's-complement form. One 
operand is always in one of the 16 general registers; 
the other operand may be in main storage or in a 
general register. 

The instruction set provides for loading, adding, 
subtracting, comparing, multiplying, dividing, and 
storing, as well as for the sign control, radix conver- 
sion, and shifting of fixed-point operands. The entire 
instruction set is included in the standard instruction 
set. 

The condition code is set as a result of all sign- 
control, add, subtract, compare, and shift operations. 



use a 64-bit decimal field. These data must be located 
on integral storage boundaries for these units of infor- 
mation, that is, double word, fuUword, or halfword 
operands must be addressed with three, two, or one 
low-order address bit(s) set to zero. 

A halfword operand in main storage is extended to 
a full word as the operand is fetched from storage. 
Subsequently, the operand participates as a full word 
operand. 

In all discussions of fixed-point numbers in this pub- 
lication, the expression "32-bit signed integer" denotes 
a 31-bit integer with a sign bit, and the expression "64- 
bit signed integer" denotes a 63-bit integer with a sign 
bit. 



Dofcr Format 

Fixed-point numbers occupy a fixed-length format 
consisting of a one-bit sign followed by the integer 
field. When held in one of the general registers, a 
fixed-point quantity has a 31-bit integer field and oc- 
cupies all 32 bits of the register. Some multiply, divide, 
and shift operations use an operand consisting of 64 
bits with a 63-bit integer field. These operands are 
located in a pair of adjacent general registers and are 
addressed by an even address referring to the left- 
most register of the pair. The sign-bit position of the 
rightmost register contains part of the integer. In reg- 
ister-to-register operations the same register may be 
specified for both operand locations. 

Full Word Fixed-Point Number 



Integer 



Halfword Fixed-Point Number 



Integer 



Fixed-point data in main storage occupy a 32-bit word 
or a 16-bit halfword, with a binary integer field of 31 
or 15 bits, respectively. The conversion instructions 



Number Representation 

All fixed-point operands are treated as signed integers. 
Positive numbers are represented in true binary nota- 
tion with the sign bit set to zero. Negative numbers 
are represented in two's-complement notation with a 
one in the sign bit. The two's-complement representa- 
tion of a negative number may be considered the sum 
of the integer part of the field, taken as a positive 
number, and the maximum negative number. The 
two's complement of a number is obtained by invert- 
ing each bit of j:he number and adding a one in the 
low-order bit position. 

This type of number representation can be consider- 
ed the low-order portion of an infinitely long represen- 
tation of the number. When the number is positive, all 
bits to the left of the most significant bit of the num- 
ber, including the sign bit, are zeros. When the num- 
ber is negative, all these bits, including the sign bit, 
are ones. Therefore, when an operand must be ex- 
tended with high-order bits, the expansion is achieved 
by prefixing a field in which each bit is set equal to 
the high-order bit of the operand. 

Two's-complement notation does not include a nega- 
tive zero. It has a number range in which the set of 
negative numbers is one larger than the set of positive 
numbers. The maximum positive number consists of 
an all-one integer field with a sign bit of zero, whereas 
the maximum negative number (the negative number 
with the greatest absolute value) consists of an all- 
zero integer field with a one-bit for sign. 
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The CPU cannot represent the complement of the 
maximum negative number. When an operation, such 
as a subtraction from zero, produces the complement 
of the maximum negative number, the number remains 
unchanged, and a fixed-point overflow exception is 
recognized. An overflow does not result, however, 
when the number is complemented and the final re- 
sult is within the representable range. An example of 
this case is a subtraction from minus one. The product 
of two maximum negative numbers is representable as 
a double-length positive number. 

The sign bit is leftmost in a number. In an arithme- 
tic operation, a carry out of the integer field changes 
the sign. However, in algebraic left-shifting the sign 
bit does not change even if significant high-order bits 
are shifted out of the integer field. 



Instruction Format 

Fixed-point instructions use the following three for- 
mats: 

RR Format 



Op Code 


^ 


Rj 



7 8 11 12 15 



RX Format 



Op Code 


«i 


^2 


h 


°2 


7 

RS Format 


8 11 12 15 16 1920 




31 


Op Code 


«1 


h 


h 


°2 



Condition Code 

The results of fixed-point sign-control, add, subtract, 
compare, and shift operations are used to set the condi- 
tion code in the program status word ( psw ) . All other 
fixed-point operations leave this code undisturbed. 
The condition code can be used for decision-making 
by subsequent branch-on-condition instructions. 

The condition code can be set to reflect three types 
of results for fixed-point arithmetic. For most opera- 
tions, the states 0, 1, or 2 indicate a zero, less than 
zero, or greater than zero content of the result reg- 
ister, while the state 3 is used when the result over- 
flows. 

For a comparison, the states 0, 1, or 2 indicate that 
the first operand is equal, low, or high. 

For ADD LOGICAL and subtract logical, the codes 
and 1 indicate a zero or nonzero result register con- 
tent in the absence of a logical carry out of the sign 
position; the codes 2 and 3 indicate a zero or nonzero 
result register content with a logical carry out of the 
sign position. 



CONDITION CODE 


SETTINGS FOR FIXED-POINT ARITHMETIC 







1 


2 


3 


Add H/F 


zero 


< zero 


> zero 


overflov^' 


Add Logical 


zero 


not zero, 


zero, 


not zero, 




no carry 


no carry 


carry 


carry 


Compare H/F 


equal 


low 


high 


— 


Load and Test 


zero 


< zero 


> zero 


— 


Load Complement 


zero 


< zero 


> zero 


overflow 


Load Negative 


zero 


< zero 


— 


~ 


Load Positive 


zero 


.- 


> zero 


overflow 


Shift Left Double 


zero 


< zero 


> zero 


overflow 


Shift Left Single 


zero 


< zero 


> zero 


overflow 


Shift Right Double 


zero 


< zero 


> zero 


— 


Shift Right Single 


zero 


< zero 


> zero 


~ 


Subtract H/F 


zero 


< zero 


> zero 


overflow 


Subtract Logical 


~ 


not zero, 


zero, 


not zero, 






no carry 


carry 


carry 



In these formats, Ri specifies the general register con- 
taining the first operand. The second operand loca- 
tion, if any, is defined differently for each format. 

In the RR format, the R2 field specifies the general 
register containing the second operand. The same reg- 
ister may be specified for the first and second operand. 

In the RX format, the contents of the general reg- 
isters specified by the X2 and B2 fields are added to 
the content of the D2 field to form an address designat- 
ing the storage location of the second operand. 

In the RS format, the content of the general register 
specified by the B2 field is added to the content of the 
D2 field. This sum designates the storage location of 
the second operand in load multiple and store 
MULTIPLE. In the shift operations, the sum specifies the 
number of bits of the shift. The R3 field specifies the 
address of a general register in load multiple and 
STORE MULTIPLE and is ignored in the shift operations. 

A zero in an X2 or B2 field indicates the absence of 
the corresponding address component. 

An instruction can specify the same general register 
both for address modification and for operand loca- 
tion. Address modification is always completed before 
operation execution. 

Results replace the first operand, except for store 
and CONVERT to DEaMAL, where the result replaces 
the second operand. 

The contents of all general registers and storage 
locations participating in the addressing or execution 
part of an operation remain unchanged, except for the 
storing of the final result. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction. For load and test. 



Fixed-Point Arithmetic 25 



for example, ltr is the mnemonic and Ri, R2 the oper- 
and designation. 



Instructions 

The fixed-point arithmetic instructions and their mne- 
monics, formats, and operation codes are listed in the 
following table. The table also indicates when the con- 
dition code is set and the exceptional conditions in 
operand designations, data, or results that cause a pro- 
gram interruption. 



Load 

Load 

Load Halfword 

Load and Test 

Load Complement 

Load Positive 

Load Negative 

Load Multiple 

Add 

Add 

Add Halfword 

Add Logical 

Add Logical 

Subtract 

Subtract 

Subtract Halfword 

Subtract Logical 

Subtract Logical 

Compare 

Compare 

Compare Halfword 

Multiply 

Multiply 

Multiply Halfword 

Divide 

Divide 

Convert to Binary 

Convert to Decimal 

Store 

Store Halfword 

Store Multiple 

Shift Left Single 

Shift Right Single 

Shift Left Double 

Shift Right Double 



MNEMONIC 

LR 

L 

LH 

LTR 

LCR 

LPR 

LNR 

LM 

AR 

A 

AH 

ALR 

AL 

SR 

S 

SH 

SLR 

SL 

CR 

C 

CH 

MR 

M 

MH 

DR 

D 

CVB 

CVD 

ST 

STH 

STM 

SLA 

SRA 

SLDA 

SRDA 



EXCEPTIONS 



RR 

RX 
RX 
RR 
RR 
RR 
RR 
RS 
RR 
RX 
RX 
RR 
RX 
RR 
RX 
RX 
RR 
RX 
RR 
RX 
RX 
RR 
RX 
RX 
RR 
RX 
RX 
RX 
RX 
RX 
RS 
RS 
RS 
RS 
RS 



P,A,S 
P,A,S 



P,A,S 

P,A,S, 
P,A,S, 

P,A,S 

P,A,S, 
P,A,S, 

P,A,S 



IF 
IF 



IF 
IF 
IF 



IF 
IF 
IF 



IK 

IK 



P,A,S 
P,A,S 

S 
P,A,S 
P,A,S 

S, 
P,A,S, 
P,A,S,D,IK 
P,A,S 
P,A,S 
P,A,S 
P,A,S 

IF 

S, IF 



CODE 
18 

58 

48 

12 

13 

10 

11 

98 

lA 

5A 

4A 

IE 

5E 

IB 

5B 

4B 

IF 

5F 

19 

59 

49 

IC 

5C 

4C 

ID 

5D 

4F 

4E 

50 

40 

90 

8B 

8A 

8F 

8E 



A Addressing exception 

C Condition code is set 

D Data exception 

IF Fixed-point overflow exception 

IK Fixed-point divide exception 

P Protection exception 

S Specification exception 



Programming Note 

The logical comparisons, shifts, and connectives, as 

well as LOAD ADDRESS, BRANCH ON COUNT, BRANCH ON 
INDEX HIGH, and BRANCH ON INDEX LOW OR EQUAL, also 

may be used in fixed-point calculations. 



Load 

LR R„R2 [RR] 



18 


^ 


h 



7 8 11 12 15 

L R„D,(X„B,) [RX] 



58 



M 



X, 



The second operand is placed in the first operand lo- 
cation. The second operand is not changed. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection (fetch violation by L only) 
Addressing (L only) 
Specification (Lonly) 

Load Halfword 

LH RyD2(X2,B2) [RX] 



48 



The halfword second operand is placed in the first 
operand location. 

The halfword second operand is expanded to a full- 
word by propagating the sign-bit value through the 
16 high-order bit positions. Expansion occurs aft€5r the 
operand is obtained from storage and before insertion 
in the register. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection ( fetch violation ) 

Addressing 

Specification 



Load and Test 



LTR Ru R, 



[RR] 



12 


«1 


"2 



The second operand is placed in the first operand loca- 
tion, and the sign and magnitude of the second op- 
erand determine the condition code. The second op- 
erand is not changed. 
Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 - 

Program Interruptions: None. 



26 



Programming Note 

When the same register is specified as first and second 
operand location, the operation is equivalent to a test 
without data movement. 



Load Complement 
ICR Ri, Rz [RR] 



13 


^1 


R2 



7 8 11 12 15 

The two's complement of the second operand is placed 
in the first operand location. 

An overflow condition occurs when the maximum 
negative number is complemented; the number re- 
mains unchanged. The overflow causes a program in- 
terruption when the fixed-point overflow mask bit is 
one. 

Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Overflow 
Program Interruptions: 

Fixed-point overflow 

Programming Note 

Zero remains invariant under complementation. 



Load Positive 

LPR Ri, R2 [RR] 



10 


«I 


"2 



7 8 11 12 15 

The absolute value of the second operand is placed in 
the first operand location. 

The operation includes complementation of nega- 
tive numbers; positive numbers remain unchanged. 

An overflow condition occurs when the maximum 
negative number is complemented; the number re- 
mains unchanged. The overflow causes a program in- 
terruption when the fixed-point overflow mask bit is 
one. 

Resulting Condition Code: 

Result is zero 

1 ~ 

2 Result is greater than zero 

3 Overflow 
Program Interruptions: 

Fixed-point overflow 



Load Negative 

LNR Ry R2 [RR] 



n 


^1 


R2 



7 8 11 12 15 



The two's complement of the absolute value of the 
second operand is placed in the first operand location. 
The operation complements positive numbers; nega- 
tive numbers remain unchanged. The number zero 
remains unchanged with positive sign. 
Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 ~ 

3 ~ 

Program Interruptions: None. 



Load Multiple 

LM Ri, R3, D,(B,) [RS] 



98 


''l 


^3 


S 


■^2 



11 12 15 16 1920 



The set of general registers starting with the register 
specified by Ri and ending with the register specified 
by R3 is loaded from the locations designated by the 
second operand address. 

The storage area from which the contents of the 
general registers are obtained starts at the location 
designated by the second operand address and con- 
tinues through as many words as needed. The general 
registers are loaded in the ascending order of their 
addresses, starting with the register specified by Ri 
and continuing up to and including the register speci- 
fied by R;{, with register following register 15. 

The second operand remains unchanged. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (fetch violation) 

Addressing 

Specification 



Programming Note 

All combinations of register addresses specified by Ri 
and R3 are valid. When the register addresses are 
equal, only one word is transmitted. When the address 
specified by R3 is less than the address specified by Ri, 
the register addresses wrap around from 15 to 0. 
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Add 

AR Rj, R2 [RR] 



lA 


^ 


R2 



7 8 1112 15 

A Ri, D^iXz, B2) [RX] 



5A 


^ 


\ 


h 


°2 



The second operand is added to the first operand, 
and the sum is placed in the first operand location. 

Addition is performed by adding all 32 bits of both 
operands. If the carries out of the sign-bit position and 
the high-order numeric bit position agree, the sum is 
satisfactory; if they disagree, an overflow occurs. The 
sign bit is not changed after the overflow. A positive 
overflow yields a negative final sum, and a negative 
overflow results in a positive sum. The overflow causes 
a program interruption when the fixed-point overflow 
mask bit is one. 

Resulting Condition Code: 

Sum is zero 

1 Sum is less than zero 

2 Sum is greater than zero 

3 Overflow 
Program Interruptions: 

Protection ( fetch violation by A only ) 
Addressing (A only) 
Specification (A only) 
Fixed-point overflow 

Programming Note 

In two's-complement notation, a zero result is always 
positive. 

Add Ha If word 

AH R„D,(X2,B2) [RX] 



4A 


h 


^2 


h 


°2 



The halfword second operand is added to the first 
operand and the sum is placed in the first operand 
location. 

The halfword second operand is expanded to a full- 
word before the addition by propagating the sign-bit 
value through the 16 high-order bit positions. 

Addition is performed by adding all 32 bits of both 
operands. If the carries out of the sign-bit position 
and the high-order numeric bit position agree, the 
sum is satisfactory; if they disagree, an overflow oc- 
curs. The sign bit is not changed after the overflow. 
A positive overflow yields a negative final sum, and a 



negative overflow results in a positive sum. The over- 
flow causes a program interruption when the fixed- 
point overflow mask bit is one. 

Resulting Condition Code: 

Sum is zero 

1 Sum is less than zero 

2 Sum is greater than zero 

3 Overflow 

Program Interruptions: 

Protection ( fetch violation ) 
Addressing 
Specification 
Fixed-point overflow 



Add Logical 

ALR Rj, R2 [RR] 



IE 


^1 


"2 



AL R„D2(X2,B2) 



[RX] 



5E 



7 8 11 12 1516 1920 



The second operand is added to the first operand, and 
the sum is placed in the first operand location. The oc- 
currence of a carry out of the sign position is recorded 
in the condition code. 

Logical addition is performed by adding all 32 bits 
of both operands without further change to the result- 
ing sign bit. The instruction differs from add in the 
meaning of the condition code and in the absence of 
the interruption for overflow. 

If a carry out of the sign position occurs, the leftmost 
bit of the condition code (psw bit 34) is made one. In 
the absence of a carry, bit 34 is made zero. When the 
sum is zero, the rightmost bit of the condition code 
( PSW bit 35 ) is made zero. A nonzero sum is indicated 
by a one in bit 35. 

Resulting Condition Code: 

Sum is zero (no carry) 

1 Sum is not zero (no carry) 

2 Sum is zero (carry) 

3 Sum is not zero (carry) 

Program Interruptions: 

Protection (fetch violation by al only) 
Addressing (ALonly) 
Specification ( al only ) 
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Subtract 

SR Ri, R2 [RR] 



IB 


«1 


"2 



7 8 n 12 15 



S R„D2(X2,B2) 



[RX] 



5B 


«1 


^2 


h 


°2 



The second operand is subtracted from the first op- 
erand, and the difference is placed in the first operand 
location. 

Subtraction is performed by adding the two's com- 
plement of the second operand to the first operand. 
All 32 bits of both operands participate, as in add. If 
the carries out of the sign-bit position and the high- 
order numeric bit position agree, the difference is sat- 
isfactory; if they disagree, an overflow occurs. The 
overflow causes a program interruption when the fixed- 
point overflow mask bit is one. 

Resulting Condition Code: 

DiflFerence is zero 

1 DiflFerence is less than zero 

2 DiflFerence is greater than zero 

3 Overflow 
Program Interruptions: 

Protection ( fetch violation by S only ) 
Addressing (S only) 
Specifications ( S only ) 
Fixed-point overflow 

Programming Note 

When the same register is specified as first and second 
operand location, subtracting is equivalent to clearing 
the register. 

Subtracting a maximum negative number from an- 
other maximum negative number gives a zero result 
and no overflow. 

Subtract Half word 

SH R„ D-JXs, Bo) [RX] 



4B 


^ 


^2 


«2 


^2 



The halfword second operand is subtracted from the 
first operand, and the diflFerence is placed in the first 
operand location. 

The halfword second operand is expanded to a full- 
word before the subtraction by propagating the sign- 
bit value through 16 high-order bit positions. 

Subtraction is performed by adding the two's com- 



plement of the expanded second operand to the first 
operand. All 32 bits of both operands participate, as in 
ADD. If the carries out of the sign-bit position and the 
high-order numeric bit position agree, the diflFerence 
is satisfactory; if they disagree, an overflow occurs. 
The overflow causes a program interruption when the 
fixed-point overflow mask bit is one. 
Resulting Condition Code: 

DiflFerence is zero 

1 DiflFerence is less than zero 

2 DiflFerence is greater than zero 

3 Overflow 
Program Interruptions: 

Protection (fetch violation) 
Addressing 
Specification 
Fixed-point overflow 

Subtract Logical 

SLR Ri, R2 [RR] 



IF 


^ 


^2 



St Ri, D^iXs, 82) 



[RX] 



5F 


«1 


^2 


»2 


''2 



The second operand is subtracted from the first op- 
erand, and the diflFerence is placed in the first operand 
location. The occurrence of a carry out of the sign 
position is recorded in the condition code. 

Logical subtraction is performed by adding the two's 
complement of the second operand to the first oper- 
and. All 32 bits of both operands participate, without 
further change to the resulting sign bit. The instruction 
diflFers from subtract in the meaning of the condition 
code and in the absence of the interruption for over- 
flow. 

If a carry out of the sign position occurs, the left- 
most bit of the condition code (psw bit 34) is made 
one. In the absence of a carry, bit 34 is made zero. 
When the sum is zero, the rightmost bit of the condi- 
tion code (psw bit 35) is made zero. A nonzero sum 
is indicated by a one in bit 35. 

Resulting Condition Code: 

- 

1 DiflFerence is not zero ( no carry ) 

2 DiflFerence is zero (carry) 

3 DiflFerence is not zero (carry) 
Program Interruptions: 

Protection (fetch violation by sl only) 
Addressing (sLonly) 
Specification (sLonly) 
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Programming Note 

A zero diflFerence cannot be obtained without a carry 
out of the sign position. 

Compare 

CR Ri. R2 [RR] 



19 


^1 


R2 



7 8 

C Ri,D,(X2,B2) 



n 12 15 
[RX] 



59 


«I 


^2 


^2 


°2 



The first operand is compared with the second op- 
erand, and the result determines the setting of the 
condition code. 

Comparison is algebraic, treating both comparands 
as 32-bit signed integers. Operands in registers or 
storage are not changed. 

Resulting Condition Code: 

Operands are equal 

1 First operand is low 

2 First operand is high 

3 - 

Program Interruptions: 

Protection (fetch violation by C only) 
Addressing (C only) 
Specification (C only) 

Compare Halfword 

CH Rj,D2(X2,Bo> [RX] 



49 


«i 


><2 


h 


°2 



The first operand is compared with the halfword sec- 
ond operand, and the result determines the setting of 
the condition code. 

The halfword second operand is expanded to a full- 
word before the comparison by propagating the sign- 
bit value through the 16 high-order bit positions. 

Comparison is algebraic, treating both comparands 
as 32-bit signed integers. Operands in registers or 
storage are not changed. 

Resulting Condition Code: 

Operands are equal 

1 First operand is low 

2 First operand is high 

3 - 

Program Interruptions: 

Protection ( fetch violation ) 

Addressing 

Specification 



Multiply 

Mk Kj, Kg 



[RR] 



IC 


^1 


R2 



7 8 11 12 15 



M Ri, DafXg, B2) [RX] 



5C 


"1 


^2 


"2 


°2 



7 8 11 12 1516 1920 



The product of the multiplier (the second operand) 
and the multiplicand (the first operand) replaces the 
multiplicand. 

Both multiplier and multiplicand are 32-bit signed 
integers. The product is always a 64-bit signed integer 
and occupies an even/odd register pair. Because the 
multiplicand is replaced by the product, the Ri field 
of the instruction must refer to an even-numbered reg- 
ister. A specification exception occurs when Ri is odd. 
The multiplicand is taken from the odd register of the 
pair. The content of the even-numbered register re- 
placed by the product is ignored, unless the register 
contains the multiplier. An overflow cannot occur. 

The sign of the product is determined by the rules 
of algebra from the multiplier and multiplicand sign, 
except that a zero result is always positive. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (fetch violation by M only) 

Addressing (M only) 

Specification 

Programming Note 

The significant part of the product usually occupies 62 
bits or fewer. Only when two maximum negative 
numbers are multiplied are 63 significant product bits 
formed. Since two's-complement notation is used, the 
sign bit is extended right until the first significant 
product digit is encountered. 

Multiply Halfword 

MH Ri, DoiXs, B2) [RX] 



4C 



'1 



X, 



The product of the halfword multiplier (second op- 
erand) and multiplicand (first operand) replaces the 
multiplicand. 

Both multiplicand and product are 32-bit signed 
integers and may be located in any general register. 
The halfword multiplier is expanded to a fuUword 
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before multiplication by propagating the sign-bit value 
through the 16 high-order bit positions. The multi- 
plicand is replaced by the low-order part of the prod- 
uct. The bits to the left of the 32 low-order bits are 
not tested for significance; no overflow indication is 
given. 

The sign of the product is determined by the rules 
of algebra from the multiplier and multiplicand sign, 
except that a zero result is always positive. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection ( fetch violation ) 

Addressing 

Specification 

Programming Note 

The significant part of the product usually occupies 46 
bits or fewer, the exception being 47 bits when both 
operands are maximum negative. Since the low-order 
32 bits of the product are stored unchanged, ignoring 
all bits to the left, the sign bit of the result may differ 
from the true sign of the product in the case of over- 
flow. 

Divide 

DR Ri, Rs [RR] 



ID 


"l 


Rj 



7 8 11 12 IS 



D R„ DgfXg, B2) 



[RX] 



5D 


"1 


^2 


»2 


°2 



The dividend ( first operand ) is divided by the divisor 
(second operand) and replaced by the quotient and 
remainder. 

The dividend is a 64-bit signed integer and occupies 
the even/odd pair of registers specified by the Ri field 
of the instruction. A specification exception occurs 
when Ri is odd. A 32-bit signed remainder and a 
32-bit signed quotient replace the dividend in the 
even-numbered and odd-numbered registers, respec- 
tively. The divisor is a 32-bit signed integer. 

The sign of the quotient is determined by the rules 
of algebra. The remainder has the same sign as the 
dividend, except that a zero quotient or a zero re- 
mainder is always positive. All operands and results 
are treated as signed integers. When the relative 
magnitude of dividend and divisor is such that the 
quotient cannot be expressed by a 32-bit signed integ- 
er, a fixed-point divide exception is recognized (a 



program interruption occurs, no division takes place, 
and the dividend remains unchanged in the general 
registers ) . 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection ( fetch violation by D only ) 
Addressing (D only) 
Specification 
Fixed-point divide 

Programming Note 

Division applies to fullword operands in storage only. 

Convert to Binary 

CVB Ri, Do(X2, B2) [RX] 



4F 


^ 


^2 


»2 


°2 



7 8 11 12 IS 14 1920 31 

The radix of the second operand is changed from deci- 
mal to binary, and the result is placed in the first 
operand location. The number is treated as a right- 
aligned signed integer both before and after conver- 
sion. 

The second operand has the packed decimal data 
format and is checked for valid sign and digit codes. 
Improper codes are a data exception and cause a pro- 
gram interruption. The decimal operand occupies a 
double-word storage field, which must be located on 
an integral boundary. The low-order four bits of the 
field represent the sign. The remaining 60 bits contain 
15 binary-coded-decimal digits in true notation. The 
packed decimal data format is described under "Deci- 
mal Arithmetic." 

The result of the conversion is placed in the general 
register specified by Ri. The maximum number that 
can be converted and still be contained in a 32-bit 
register is 2,147,483,647; the minimum number is 
—2,147,483,648. For any decimal number outside this 
range, the operation is completed by placing the 32 
low-order binary bits in the register; a fixed-point 
divide exception exists, and a program interruption 
follows. In the case of a negative second operand, the 
low-order part is in two's-complement notation. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection ( fetch violation ) 

Addressing 

Specification 

Data 

Fixed-point divide 
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Convert to Decimal 

CVD Rj, D.JX2, B2) [RX] 



4E 



R, X2 



7 B 11 12 IS 16 1920 



The radix of the first operand is changed from binary 
to decimal, and the result is stored in the second op- 
erand location. The number is treated as a right- 
aligned signed integer both before and after con- 
version. 

The result is placed in the storage location desig- 
nated by the second operand and has the packed 
decimal format, as described in "Decimal Arithmetic' 
The result occupies a double-word in storage and must 
be located on an integral boundary. The low-order 
four bits of the field represent the sign. A positive sign 
is encoded as 1100 or 1010; a negative sign is encoded 
as 1101 or 1011. The choice between the two sign 
representations is determined by the state of psw bit 
12. The remaining 60 bits contain 15 binary-coded- 
decimal digits in true notation. 

The number to be converted is obtained as a 32-bit 
signed integer from a general register. Since 15 deci- 
mal digits are available for the decimal equivalent of 
31 bits, an overflow cannot occur. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (store violation) 

Addressing 

Specification 



Store 

ST Ri, DsiXz, B.J [RX] 



50 


«1 


Xj 


=2 


"2 



7 8 11 12 . 15 16 1920 



The first operand is stored at the second operand 
location. 

The 32 bits in the general register are placed un- 
changed at the second operand location. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection ( store violation ) 

Addressing 

Specification 



Store Ha If word 

STH Ri, DJXs, Bo) [RX] 



40 



M 



The first operand is stored at the halfword second 
operand location. 

The 16 low-order bits in the general register are 
placed unchanged at the second operand location. The 
16 high-order bits of the first operand do not partici- 
pate and are not tested. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection (store violation) 

Addressing 

Specification 

Store Multiple 

STM Ri, R^, DoiBo) [RS] 



90 



M 



The set of general registers starting with the register 
specified by Ri and ending with the register specified 
by R3 is stored at the locations designated by the 
second operand address. 

The storage area where the contents of the general 
registers are placed starts at the location designated 
by the second operand address and continues through 
as many words as needed. The general registers are 
stored in the ascending order of their addresses, start- 
ing with the register specified by Ri and continuing 
up to and including the register specified by R3, with 
register following register 15. The contents of the 
general registers remain unchanged. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection (store violation) 

Addressing 

Specification 

Shift Left Single 

St A Ru D.JB-J [RS] 



8B 



7 8 11 12 15 16 1920 



The integer part of the first operand is shifted left the 
number of bits specified by the second operand ad- 
dress. 



32 



The second operand address is not used to address 
data; its low-order six bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

The sign of the first operand remains unchanged. All 
31 integer bits of the operand participate in the left 
shift. Zeros are supplied to the vacated low-order reg- 
ister positions. 

If a bit unlike the sign bit is shifted out of position 
1, an overflow occurs. The overflow causes a program 
interruption when the fixed-point overflow mask bit 
is one. 

Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Overflow 
Program Interruptions: 

Fixed-point overflow 

Programming Note 

For numbers with an absolute value of less than 2^", 
a left shift of one bit position is equivalent to multi- 
plying the number by 2. 

Shift amounts from 31-63 cause the entire integer to 
be shifted out of the register. When the entire integer 
field for a positive number has been shifted out, the 
register contains a value of zero. For a negative num- 
ber, the register contains a value of — 2'^^ 

The base register participating in the generation of 
the second operand address permits indirect specifi- 
cation of the shift amount. A zero in the B2 field indi- 
cates the absence of indirect shift specification. 

Shift Right Single 

SRA R„ D2(B.J [RS] 



8A 


^ 


« 


^2 


^2 



The integer part of the first operand is shifted right 
the number of bits specified by the second operand 
address. 

The second operand address is not used to address 
data; its low-order six bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

The sign of the first operand remains unchanged. 
All 31 integer bits of the operand participate in the 
right shift. Bits equal to the sign are supplied to the 
vacated high-order bit positions. Low-order bits are 
shifted out without inspection and are lost. 



Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 ~ 

Program Interruptions: 
None. 

Programming Note 

A right shift of one bit position is equivalent to divi- 
sion by 2 with rounding downward. When an even 
number is shifted right one position, the value of the 
field is that obtained by dividing the value by 2. When 
an odd number is shifted right one position, the value 
of the field is that obtained by dividing the next lower 
number by 2. For example, -|-5 shifted right by one 
bit position yields +2, whereas —5 yields —3. 

Shift amounts from 31-63 cause the entire integer to 
be shifted out of the register. When the entire integer 
field of a positive number has been shifted out, the 
register contains a value of zero. For a negative num- 
ber, the register contains a value of —1. 

The base register participating in the generation of 
the second operand address permits indirect specifica- 
tion of the shift amount. A zero in the B2 field indicates 
the absence of indirect shift specification. 

Shift Left Double 

SID A Ri, D2(B2) [RS] 



8F 


^ 


m 


h 


°2 



The double-length integer part of the first operand is 
shifted left the number of bits specified by the second 
operand address. 

The Ri field of the instruction specifies an even/odd 
pair of registers and must contain an even register 
address. A specification exception occurs when Ri is 
odd. 

The second operand address is not used to address 
data; its low-order 6-bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

The operand is treated as a number with 63 integer 
bits and a sign in the sign position of the even register. 
The sign remains unchanged. The high-order position 
of the odd register contains an integer bit, and the 
content of the odd register participates in the shift in 
the same manner as the other integer bits. Zeros are 
supplied to the vacated positions of the registers. 

If a bit unlike the sign bit is shifted out of bit posi- 
tion 1 of the even register, an overflow occurs. The 



Fixed-Point Arithmetic 33 



Form A22-6821-2, -3, -4, -5 
Page Revised 1/13/67 
By TNL' N22-0244 

overflow causes a program interruption when the fixed- 
point overflow mask bit is one. 
Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Overflow 
Program Interruptions: 

Specification 
Fixed-point overflow 



Shift Right Double 
SRDA Ri, DoJBo) 



[RS] 



8E 


h 




\ 


D2 



The double-length integer part of the first operand is 
shifted right the number of places specified by the 
second operand address. 

The Ri field of the instruction specifies an even/odd 
pair of registers and must contain an even register 
address. A specification exception occurs when Ri is 
odd. 

The second operand address is not used to address 
data; its low-order six bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

The operand is treated as a number with 63 integer 
bits and a sign in the sign position of the even register. 
The sign remains unchanged. The high-order position 
of the odd register contains an integer bit, and the 
content of the odd register participates in the shift in 
the same manner as the other integer bits. The low- 
order bits are shifted out without inspection and are 
lost. Bits equal to the sign are supplied to the vacated 
positions of the registers. 

Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 - 

Program Interruptions: 
Specification 

Programming Note 

A zero shift amount in the double-shift operations 
provides a double-length sign and magnitude test. 



Fixed-Point Arithmetic Exceptions 

Exceptional operand designations, data, or results cause 
a program interruption. When a program interruption 
occurs, tlie current psm^ is stored as an old psw, and a 



new PSW is obtained. The interruption code in the old 
PSW identifies the cause of the interruption. The 
following exceptions cause a program interruption in 
fixed-point arithmetic. 

Protection: The key of an operand in storage does 
not match the protection key in the psw. The opesration 
is suppressed for a store violation. Therefore, the con- 
dition code and data in registers and storage remain 
unchanged. The only exception is store multiple, 
which is terminated; the amount of data stored is un- 
predictable and should not be used for further compu- 
tation. The operation is terminated on any fetch viola- 
tion. 

Addressing: An address designates an operand loca- 
tion outside the available storage for a particular in- 
stallation. In most cases, the operation is terminated. 
Therefore, the result data are unpredictabl(5 and 
should not be used for further computation. The ex- 
ceptions are store, store halfword, and convert to 
DECIMAL, which are suppressed. Operand addresses are 
tested only when used to address storage. Addresses 
used as a shift amount are not tested. The address re- 
strictions do not apply to the components from which 
an address is generated — the content of the D2 field 
and the contents of the registers specified by X2 and B2. 

Specification: A double-word operand is not located 
on a 64-bit boundary, a fullword operand is not located 
on a 32-bit boundary, a halfword operand is not lo- 
cated on a 16-bit boundary, or an instruction specifies 
an odd register address for a pair of general registers 
containing a 64-bit operand. The operation is sup- 
pressed. Therefore, the condition code and data in reg- 
isters and storage remain unchanged. 

Data: A sign or a digit code of the decimal operand 
in convert to binary is incorrect. The operation is 
suppressed. Therefore, the condition code and data in 
registers and storage remain unchanged. 

Fixed-Point Overflow: The result of a sign-control, 
add, subtract, or shift operation overflows. The inter- 
ruption occurs only when the fixed-point overflow 
mask bit is one. The operation is completed by placing 
the truncated low-order result in the register and set- 
ting the condition code to 3. The overflow bits are lost. 
In add-type operations the sign stored in the register 
is the opposite of the sign of the sum or difference. In 
shift operations the sign of the shifted number remains 
unchanged. The state of the mask bit does not affect 
the result. 

Fixed-Point Divide: The quotient of a division ex- 
ceeds the register size, including division by zero, or 
the result in convert to binary exceeds 31 bits. Divi- 
sion is suppressed. Therefore, data in the registers 
remain unchanged. The conversion is completed Ijy re- 
cording the truncated low-order result in the register. 
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Decimal Arithmetic 



Decimal arithmetic operates on data in the packed 
format. In this format, two decimal digits are placed 
in one eight-bit byte. Since data are often communi- 
cated to or from external devices in the zoned format 
(which has one digit in an eight-bit byte), the neces- 
sary format-conversion operations are also provided 
in this instruction group. 

Data are interpreted as integers, right-aligned in 
their fields. They are kept in true notation with a sign 
in the low-order eight-bit byte. 

Processing takes place right to left between main- 
storage locations. All decimal arithmetic instructions 
use a two-address format. Each address specifies the 
leftmost byte of an operand. Associated with this ad- 
dress is a length field, indicating the number of addi- 
tional bytes that the operand extends beyond the first 
byte. 

The decimal arithmetic instruction set provides for 
adding, subtracting, comparing, multiplying, and di- 
viding, as well as the format conversion of variable- 
length operands. All of the instructions discussed in 
this section except pack, unpack, and move with off- 
set are part of the decimal feature. 

The condition code is set as a result of all add-type 
and comparison operations. 



Data Format 

Decimal operands reside in main storage only. They 
occupy fields that may start at any byte address and 
are composed of one to 16 eight-bit bytes. 

Lengths of the two operands specified in an instruc- 
tion need not be the same. If necessary they are con- 
sidered to be extended with zeros to the left of the 
high-order digits. Results never exceed the limits set 
by address and length specification. Lost carries or 
lost digits from arithmetic operations are signaled as 
a decimal overflow exception. 

Although decimal arithmetic is performed on data 
in the packed format, decimal operands may be either 
in the packed or zoned format. 

Packed Decimal Number 



byte of the field. In the rightmost byte a sign is placed 
to the right of decimal digit. Both digits and a sign 
are encoded and occupy four bits each. 



Digif 


Digit- 


Digit 



Digit 


Digit 


Digit 


Digit 


Sign 



Zoned Decimal Number 



Zone 


Digit 


Zone 



Digit 


Zone 


Digit 


Sign 


Digit 



In the packed format, two decimal digits normally are 
placed adjacent in a byte, except for the rightmost 



In the zoned format the low-order four bits of a byte, 
the numeric, are normally occupied by a decimal digit. 
The four high-order bits of a byte are called the zone, 
except for the rightmost byte of the field, where nor- 
mally the sign occupies the zone position. 

Arithmetic is performed with operands in the 
packed format and results in the packed format. In the 
zoned format, the digits are represented as part of an 
alphameric character set. A pack instruction is pro- 
vided to transform zoned data into packed data, and 
an unpack instruction performs the reverse transforma- 
tion. Moreover, the editing instructions may be used 
to change data from packed to zoned. 

The fields specified in decimal arithmetic other than 
in pack, unpack, and move with offset either should 
not overlap at all or should have coincident rightmost 
bytes. In zero and add, the destination field may also 
overlap to the right of the source field. Because the 
code configurations for digits and sign are verified 
during arithmetic, improper overlapping fields are 
recognized as data exceptions. In move-type oper- 
ations, the operand digits and signs are not checked, 
and the operand fields may overlap without any re- 
strictions. 

The rules for overlapped fields are established for 
the case where operands are fetched right to left from 
storage, eight bits at a time, just before they are pro- 
cessed. Similarly, the results are placed in storage, 
eight bits at a time, as soon as they are generated. 
Actual processing procedure may be considerably dif- 
ferent because of the use of preferred storage for in- 
termediate results. Nevertheless, the same rules are 
observed. 



Number Representation 

Numbers are represented as right-aligned true integ- 
ers with a plus or minus sign. 

The digits 0-9 have the binary encoding 0000-1001. 
The codes 1010-1111 are invalid as digits. This set of 
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codes is interpreted as sign codes, with 1010, 1100, 
1110, and 1111 recognized as plus and with 1011 and 
1101 recognized as minus. The codes 0000-1001 are 
invaHd as sign codes. The zones are not tested for 
valid codes inasmuch as they are eliminated in chang- 
ing data from the zoned to the packed format. 

The sign and zone codes generated for all decimal 
arithmetic results differ for the extended binary-coded- 
decimal interchange code (ebcdic) and the USA 
Standard Code for Information Interchange (usascii-s). 
The choice between the two codes is determined by 
bit 12 of the psw. When bit 12 is zero, the preferred 
EBCDIC codes are generated; these are plus, 1100; 
minus, 1101; and zone, 1111. When bit 12 is one, the 
preferred usascii-8 codes are generated; these are plus, 
1010; minus, 1011; and zone, 0101. 



Condition Code 

The results of all add-type and comparison operations 
are used to set the condition code. All other decimal 
arithmetic operations leave the code unchanged. The 
condition code can be used for decision-making by 
subsequent branch-on-condition instructions. 

The condition code can be set to reflect two types 
of results for decimal arithmetic. For most operations 
the states 0, 1, and 2 indicate a zero, less than zero, 
and greater than zero content of the result field; the 
state 3 is used when the result of the operation over- 
flows. 

For the comparison operation, the states 0, 1, and 2 
indicate that the first operand compared equal, low, 
or high. 

CONDITION CODE SETTiStg FOR DECIMAL ARITHMETIC 








1 


2 


3 


Add Decimal 


zero 


< zero 


> zero 


overflow 


Compare Decimal 


equal 


low 


high 


_. 


Subtract Decimal 


zero 


< zero 


> zero 


overflow 


Zero and Add 


zero 


< zero 


> zero 


overflow 



Instruction Format 

Decimal instructions use the following format: 



5S Format 



Op Code 



mniSLin 



For this format, the content of the general register 
specified by Bi is added to the content of the Di field 
to form an address. This address specifies the leftmost 
byte of the first operand field. The number of operand 
bytes to the right of this byte is specified by the Li 



field of the instruction. Therefore, the length in bytes 
of the first operand field is 1-16, corresponding to a 
length code in Li of 0000-1111. The second operand 
field is specified similarly by the L2, B2, and D2 in- 
struction fields. 

A zero in the Bi or B2 field indicates the absence of 
the corresponding address component. 

Results of operations are always placed in the first 
operand field. The result is never stored outside the 
field specified by the address and length. In the event 
the first operand is longer than the second, the second 
operand is extended with high-order zeros up to the 
length of the first operand. Such extension never modi- 
fies storage. The second operand field and t:Jie con- 
tents of all general registers remain unchanged. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction. For add decimal, for 
example, ap is the mnemonic and Di (Li, Bi), D2 (L2, 
B2 ) the operand designation. 



Instructions 

The decimal arithmetic instructions and their mne- 
monics and operation codes follow. All instructions 
use the ss format and assume packed operands and 
results. The only exceptions are pack, which has a 
zoned operand, and unpack, which has a zoned result. 
The table indicates when the condition code is set and 
the exceptions in operand designations, data, or results 
that cause a program interruption. 



NAME 


MNEMONIC 


TYPE 


EXCEPTIONS 


CODE 


Add Decimal 


AP 


SS T,C 


P,A, D,DF 


FA 


Subtract Decimal 


SP 


ss T,C 


P,A, D,DF 


FB 


Zero and Add 


ZAP 


SS T,C 


P,A, D,DF 


F8 


Compare Decimal 


CP 


SS T,C 


P,A, D 


F9 


Multiply Decimal 


MP 


ss T 


P,A,S,D 


FC 


Divide Decimal 


DP 


SS T 


P,A,S,D,DK 


FD 


Pack 




PACK 


SS 


P,A 


F2 


Unpack 




UNPK 


SS 


P,A 


F3 


Move wi 


th Offset 


MVO 


SS 


P,A 


Fl 


NOTES 












A 


Addressing exception 








C 


Condition code is set 








D 


Data exception 








DF 


Decimal-overflow exception 






DK 


Decimal-divide exception 






P 


Protection exception 








S 


Specification exception 








T 


Decimal feature 









Programming Note 

The moving, editing, and logical comparing Instruc- 
tions may also be used in decimal calculations. 
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Add Decimal 



FA I h 1 4 1 ^1 u?Pii ^2 iir^ 



The second operand is added to the first operand, and 
the sum is placed in the first operand location. 

Addition is algebraic, taking into account sign and 
all digits of both operands. All signs and digits are 
checked for validity. If necessary, high-order zeros are 
supplied for either operand. When the first operand 
field is too short to contain all significant digits of the 
sum, a decimal overflow occurs, and a program inter- 
ruption is taken provided that the corresponding mask 
bit is one. 

Overflow has two possible causes. The first is the 
loss of a carry out of the high-order digit position of 
the result field. The second cause is an oversized re- 
sult, which occurs when the second operand field is 
larger than the first operand field and significant result 
digits are lost. The field sizes alone are not an indi- 
cation of overflow. 

The first and second operand fields may overlap 
when their low-order bytes coincide; therefore, it is 
possible to add a number to itself. 

The sign of the sum is determined by the rules of 
algebra. When the operation is completed without an 
overflow, a zero sum has a positive sign, but when 
high-order digits are lost because of an overflow, a 
zero sum may be either positive or negative, as de- 
termined by what the sign of the correct sum would 
have been. 

Resulting Condition Code: 

Sum is zero 

1 Sum is less than zero 

2 Sum is greater than zero 

3 Overflow 
Program Interruptions: 

Operation ( if decimal feature is not installed ) 

Protection (store or fetch violation) 

Addressing 

Data 

Decimal overflow 

Subtract Decimal 

SP D,a„ B,), D^d^, B2) [SS} 



FB I h 4TVl?'^l| ^2 |?p2 



7 8 11 \2 15 16 1920 3132 35 36 47 

The second operand is subtracted from the first oper- 
and, and the difference is placed in the first operand 
location. 



Subtraction is algebraic, taking into account sign 
and all digits of both operands. The subtract decimal 
is similar to add decimal, except that the sign of the 
second operand is changed from positive to negative 
or frorh negative to positive after the operand is ob- 
tained from storage and before the arithmetic. 

The sign of the difference is determined by the rules 
of algebra. When the operation is completed without 
an overflow, a zero difference has a positive sign, but 
when high-order digits are lost because of an overflow, 
a zero difference may be either positive or negative, as 
determined by what the sign of the correct difference 
would have been. 

Resulting Condition Code: 

Difference is zero 

1 Difference is less than zeio 

2 Difference is greater than zero 

3 Overflow 
Program Interruptions: 

Operation (if decimal feature is not installed) 

Protection ( store or fetch violation ) 

Addressing 

Data 

Decimal overflow 

Programming Note 

The operands of subtract decimal may overlap when 
their low-order bytes coincide, even when their 
lengths are unequal. This property may be used to set 
to zero an entire field or the low-order part of a field. 

Zero and Add 

ZAP Dj(Lu B,), D^JLs, B,) [SS] 



'^ I h 1 4 1 ^1 urT^Ti^r^ 



7 8 1112 15 16 1920 3132 35 36 47 

The second operand is placed in the first operand lo- 
cation. 

The operation is equivalent to an addition to zero. 
A zero result is positive. When high-order digits are 
lost because of overflow, a zero result has the sign of 
the second operand. 

Only the second operand is checked for valid sign 
and digit codes. Extra high-order zeros are supplied 
if needed. When the first operand field is too short to 
contain all significant digits of the second operand, a 
decimal overflow occurs and results in a program in- 
terruption, provided that the decimal overflow mask 
bit is one. The first and second operand fields may 
overlap when the rightmost byte of the first operand 
field is coincident with or to the right of the rightmost 
byte of the second operand. 
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Resulting Condition Code: 

Result is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Overflow 
Program Interruptions: 

Operation (if decimal feature is not installed) 

Protection ( store or fetch violation ) 

Addressing 

Data 

Decimal overflov^^ 



Compare Decimal 

CP Dj(Lj, Bi), Do(Lo, Bo) 



[«] 



F9 I h 4 1 ^1 u?Pii ^2 iirv 



The first operand is compared with the second, and 
the condition code indicates the comparison result. 

Comparison is right to left, taking into account thc^ 
sign and all digits of both operands. All signs and 
digits are checked for validity, and any valid plus or 
minus sign is considered equal to any other valid plus 
or minus sign, respectively. If the fields are unequal 
in length, the shorter is extended with high-order 
zeros. A field with a zero value and positive sign is 
considered equal to a field with a zero value but nega- 
tive sign. Neither operand is changed as a result of the 
operation. Overflow cannot occur in this operation. 

The first and second fields may overlap when their 
low-order bytes coincide. It is possible, therefore, to 
compare a number to itself. 

Resulting Condition Code: 

Operands equal 

1 First operand is low 

2 First operand is high 

3 - 

Program Interruptions: 
Operation ( if decimal feature is not installed ) 
Protection ( fetch violation ) 
Addressing 
Data 

Programming Note 

The COMPARE DECIMAL is unique in processing from 
right to left; taking signs, zeros, and invalid characters 
into account; and extending variable-length fields 
when they are unequal in length. 

Multiply Decimal 

MP Didu Bi), D^ds, B2) [SS] 



The product of the multiplier (the second operand) 
and the multiplicand (the first operand) replaces the 
multiplicand. 

The multiplier size is limited to 15 digits and sign 
and must be less than the multiplicand size. Length 
code L2, larger than seven, or larger than or equal to 
the length code Li, is recognized as a specification ex- 
ception. The operation is suppressed and a program 
interruption occurs. 

Since the number of digits in the product is the sum 
of the number of digits in the operands, the multi- 
plicand must have high-order zero digits for at least 
a field size that equals the multiplier field size; other- 
wise, a data exception is recognized, and a program 
interruption occurs. This definition of the multiplicand 
field insures that no product overflow can occur. The 
maximum product size is 31 digits. At least one high- 
order digit of the product field is zero. 

All operands and results are treated as signed in- 
tegers, right-aligned in their field. The sign of the 
product is determined by the rules of algebra from 
the multiplier and multiplicand signs, even if one or 
both operands are zero. 

The multiplier and product fields may overlap when 
their low-order bytes coincide. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Operation (if decimal feature is not installed) 
Protection ( store or fetch violation ) 
Addressing 
Specification 
Data 

Programming Note 

When the multiplicand does not have the desired 
number of leading zeros, multiplication may be pre- 
ceded by a ZERO and add into a larger field. 

Divide Decimal 

DP Di(L„ B,), D.(L„ B^) [SSI 



FD 



l^hHZKh 



1516 1920 



31 32 35 36 



'^ I h I ^ I ^1 R f^ ^mpT 



The dividend (the first operand) is divided by the 
divisor (the second operand) and replaced by the 
quotient and remainder. 

The quotient field is placed leftmost in the first op- 
erand field. The remainder field is placed rightmost in 
the first operand field and has a size equal to the di- 
visor size. Together, the quotient and remainder oc- 
cupy the entire dividend field; therefore, the address 
of the quotient field is the address of the first oper- 
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and. The size of the quotient field in eight-bit bytes 
is Li — L2, and the length code for this field is one 
less (Li — L2 — 1). When the divisor length code 
is larger than seven (15 digits and sign) or larger 
than or equal to the dividend length code, a specifi- 
cation exception is recognized. The operation is sup- 
pressed, and a program interruption occurs. 

The dividend, divisor, quotient, and remainder are 
all signed integers, right-aligned in their fields. The 
sign of the quotient is determined by the rules of al- 
gebra from dividend and divisor signs. The sign of the 
remainder has the same value as the dividend sign. 
These rules are true even when quotient or remainder 
is zero. 

Overflow cannot occur. A quotient larger than the 
number of digits allowed is recognized as a decimal- 
divide exception. The operation is suppressed, and a 
program interruption occurs. Divisor and dividend re- 
main unchanged in their storage locations. 

The divisor and dividend fields may overlap only if 
their low-order bytes coincide. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation ( if decimal feature is not installed ) 

Protection ( store or fetch violation ) 

Addressing 

Specification 

Data 

Decimal divide 



Programming Note 

The maximum dividend size is 31 digits and sign. 
Since the smallest remainder size is one digit and sign, 
the maximum quotient size is 29 digits and sign. 

The condition for a divide exception can be deter- 
mined by a trial subtraction. The leftmost digit of the 
divisor field is aligned with the leftmost-less-one digit 
of the dividend field. When the divisor, so aligned, is 
less than or equal to the dividend, a divide exception 
is indicated. 

A decimal-divide exception occurs if the dividend 
does not have at least one leading zero. 

Pack 

PACK D,(Li,Bj),D2(L2,Bo) [SS] 



'^ I h 1 4 1 ^1 u^Pii ^2 \)r^2 



7 8 11 12 15 16 1920 31 32 35 36 47 

The format of the second operand is changed from 
zoned to packed, and the result is placed in the first 
operand location. 
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The second operand is assumed to have the zoned 
format. All zones are ignored, except the zone over the 
low-order digit, which is assumed to represent a sign. 
The sign is placed in the right four bits of the low- 
order byte, and the digits are placed adjacent to the 
sign and to each other in the remainder of the result 
field. The sign and digits are moved unchanged to the 
first operand field and are not checked for valid codes. 

The fields are processed right to left. If necessary, 
the second operand is extended with high-order zerofs. 
If the first operand field is too short to contain all 
significant digits of the second operand field, the re- 
maining high-order digits are ignored. Overlapping 
fields may occur and are processed by storing one re- 
sult byte immediately after the necessary operand 
bytes are fetched. Except for the rightmost byte of 
the result field, which is stored immediately upon 
fetching the first operand byte, two operand bytes are 
needed for each result byte. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection ( store or fetch violation ) 
Addressing 

Programming Notes 

The PACK instruction may be used to switch the two 
digits in one byte by specifying a zero in the Li and 
L2 fields and the same address for both operands. 

To remove the zones of all bytes of a field, including 
the low-order byte, both operands must be extended 
with a dummy byte in the low-order position, which 
subsequently is ignored in the result field. 



Unpack 

UNPK Dtdi, BiK O^dz, B2) 



[«] 
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The format of the second operand is changed from 
packed to zoned, and the result is placed in the first 
operand location. 

The digits and sign of the packed operand are 
placed unchanged in the first operand location, using 
the zoned format. Zones with coding 1111 in ebcdic 
I and coding 0101 in usascii-8 are supplied for all bytes, 
except the low-order byte, which receives the sign of 
the packed operand. The operand sign and digits are 
not checked for valid codes. 

The fields are processed right to left. The second 
operand is extended with high-order zero digits before 
unpacking, if necessary. If the first operand field is too 
short to contain all significant digits of the second 
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operand, the remaining high-order digits are ignored. 
The first and second operand fields may overlap and 
are processed by storing the first result byte immedi- 
ately after the rightmost operand byte is fetched; for 
the remaining operand bytes, two result bytes are 
stored immediately after one byte is fetched. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Addressing 
Protection (store or fetch 'violation ) 

Programming Note 

A field that is to be unpacked can be destroyed by 
improper overlapping. If it is desired to save storage 
space for unpacking by overlapping the operand fields, 
the low-order position of the first operand must be to 
the right of the low-order position of the second oper- 
and by the number of bytes in the second operand 
minus two. If only one or two bytes are to be un- 
packed,, the low-order positions of the two operands 
may coincide. 

Move with OfFset 

MVO D,(Li, BiK Ds(Lo, Bgj [S5] 



Fi I h I 4 I ^1 urTTVlir^" 
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The second operand is placed to the left of and ad- 
jacent to the low-order four bits of the first operand. 

The low-order four bits of the first operand are at- 
tached as low-order bits to the second operand, the 
second operand bits are offset by four bit positions, 
and the result is placed in the first operand location. 
The first and second operand bytes are not checked 
for valid codes. 

The fields are processed right to left. If necessary, 
the second operand is extended with high-order zeros. 
If the first operand field is too short to contain all 
bytes of the second operand, the remaining informa- 
tion is ignored. Overlapping fields may occur and are 
processed by storing a result byte as soon as the neces- 
sary operand bytes are fetched. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (store or fetch violation) 
Addressing 

Programming Note 

The instruction set for decimal arithmetic includes no 
shift instructions since the equivalent of a shift can be 
obtained by programming. Programs for right or left 
shift and for an even or odd shift amount may be writ- 
ten with MOVE WITH OFFSET and the logical move in- 
structions. 



Decimal Arithmetic Exceptions 

Exceptional operation codes, operand designations, 
data, or results cause a program interruption. When 
the interruption occurs, the current psw is stored as an 
old PSW, and a new psw is obtained. The interruption 
code in the old psw identifies the cause of the inter- 
ruption. The following exceptions cause a program in- 
terruption in decimal arithmetic. 

Operation: The decimal feature is not installed and 
the instruction is add decimal, subtract decimal, 

ZERO AND ADD, COMPARE DECIMAL, MULTIPLY DECIMAL, 

or DIVIDE DECIMAL. The instruction is suppressed. 
Therefore, the condition code and data in storage and 
registers remain unchanged. 

Protection: The key of an operand in storage does 
not match the protection key in the psw. 

The operation is terminated for either a store or a 
fetch violation by a decimal instruction; the result data 
and condition code are unpredictable. 

Addressing: An address designates an operand loca- 
tion outside the available storage for the installation. 

The operation is terminated. The result data and the 
condition code are unpredictable and should not be 
used for further computation. 

These address exceptions do not apply to the com- 
ponents from which an address is generated -~ the 
contents of the Di and D2 fields and the contents of 
the registers specified by Bi and B2. 

Specifications: A multiplier or a divisor size ex- 
ceeds 15 digits and sign or exceeds the multiplicand 
or dividend size. The instruction is suppressed; 
therefore, the condition code and data in storage and 
registers remain unchanged. 

Data: A sign or digit code of an operand in add 

DECIMAL, SUBTRACT DECIMAL, ZERO AND ADD, COAfPARE 
DECIMAL, MULTIPLY DECIMAL, Or DIVIDE DECIMAL IS in- 

correct, a multiplicand has insufiicient high-order 
zeros, or the operand fields in these operations overlap 
incorrectly. The operation is terminated. The result 
data and the condition code are unpredictable and 
should not be used for further computation. 

Decimal Overflow: The result of add decimal, sub- 
tract DECIMAL, or ZERO AND ADD ovcrflows. The pro- 
gram interruption occurs only when the decimal-over- 
flow mask bit is one. The operation is completed by 
placing the truncated low-order result in the result 
field and setting the condition code to 3. The sign and 
low-order digits contained in the result field are the 
same as they would have been for an infinitely long 
result field. 

Decimal Divide: The quotient exceeds the specified 
data field, including division by zero. Division is sup- 
pressed. Therefore, the dividend and divisor remain 
unchanged in storage. 
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Floating-Point Arithmetic 



The floating-point instruction set is used to perform 
calculations on operands with a wide range of magni- 
tude and yielding results scaled to preserve precision. 

A floating-point number consists of a signed ex- 
ponent and a signed fraction. The quantity expressed 
by this number is the product of the fraction and the 
number 16 raised to the power of the exponent. The 
exponent is expressed in excess 64 binary notation; the 
fraction is expressed as a hexadecimal number having 
a radix point to the left of the high-order digit. 

To avoid unnecessary storing and loading operations 
for results and operands, four floating-point registers 
are provided. The floating-point instruction set pro- 
vides for loading, adding, subtracting, comparing, 
multiplying, dividing, and storing, as well as the sign 
control of short or long operands. Short operands gen- 
erally provide faster processing and require less stor- 
age than long operands. On the other hand, long 
operands provide greater preciseness in computation. 
Operations may be either register to register or storage 
to register. All floating-point instructions and registers 
are part of the floating-point feature. 

Maximum precision is preserved in addition, sub- 
traction, multiplication, and division by producing 
normalized results. For addition and subtraction, in- 
structions are also provided that generate unnormal- 
ized results. Normalized and unnormalized operands 
may be used in any floating-point operation. 

The condition code is set as a result of all sign con- 
trol, add, subtract, and compare operations. 



Data Format 

Floating-point data occupy a fixed-length format, 
which may be either a flillword short format or a 
double-word long format. Both formats may be used 
in main storage and in the floating-point registers. The 
floating-point registers are nvimbered 0, 2, 4, and 6. 

Short Floating-Point Number 



s 


CharacterisHc 


Fraction 






1 7 8 ^ ^' 

Long Floating-Point Number 




31 


S 


Characteristic 


Fraction 


'il 





The first bit in either format is the sign bit (S). The 
subsequent seven bit positions are occupied by the 
characteristic. The fraction field may have either six 
or 14 hexadecimal digits. 

The entire set of floating-point instructions is avail- 
able for both short and long operands. When short- 
precision is specified, all operands and results are 32- 
bit floating-point words, and the rightmost 32 bits of 
the floating-point registers do not participate in the 
operations and remain unchanged. An exception is the 
product in multiply, which is a 64-bit word and oc- 
cupies a full register. When long-precision is specified, 
all operands and results are 64-bit floating-point words. 

Although final results in short-precision have six 
fraction digits, intermediate results in add normalized, 

SUBTRACT normalized, ADD UNNORMALIZED, SUBTRACT 

UNNORMALIZED, and COMPARE may extend to seven 
fraction digits. The low-order digit of a seven-digit 
fraction is called the guard digit and serves to increase 
the precision of the final result. Intermediate results in 
long-precision do not exceed 14 fraction digits. 



Number Representation 

The fraction of a floating-point number is expressed in 
hexadecimal digits. The radix point of the fraction is 
assumed to be immediately to the left of the high- 
order fraction digit. To provide the proper magnitude 
for the floating-point number, the fraction is consid- 
ered to be multiplied by a power of 16. The character- 
istic portion, bits 1-7 of both floating-point formats, in- 
dicates this power. The bits within the characteristic 
field can represent numbers from through 127. To 
accommodate large and small magnitudes, the charac- 
teristic is formed by adding 64 to the actual exponent. 
The range of the exponent is thus —64 through -|-63. 
This technique produces a characteristic in excess 64 
notation. 

Both positive and negative quantities have a true 
fraction, the difference in sign being indicated by the 
sign bit. The number is positive or negative according- 
ly as the sign bit is zero or one. 

The range covered by the magnitude (M) of a 
normalized floating-point number is 
in short precision 16-*'^ ^ M ^ (1 -16-«) • 16«3, and 
in long precision 16-«s ^ M ^ (1 -16-1*) • 16«3, 
or approximately 5.4-10-'^^ ^ M ^ 7.2-10^^ 
in either precision. 
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A number with zero characteristic, zero fraction, and 
plus sign is called a true zero. A true zero may arise 
as the result of an arithmetic operation because of the 
particular magnitude of the operands. A result is 
forced to be true zero when an exponent underflow 
occurs or when a result fraction is zero and no pro- 
gram intelTuption due to significance exception is 
taken. When the program interruption is taken, the 
true zero is not forced, and the characteristic of the 
result remains unchanged. Whenever a result has a 
zero fraction, the exponent overflow and underflow 
exceptions do not cause a program interruption. When 
a divisor has a zero fraction, division is omitted, a 
floating-point divide exception exists, and a program 
interruption occurs. Otherwise, zero fractions and zero 
characteristics participate as normal numbers in all 
arithmetic operations. 

The sign of a sum, difference, product, or quotient 
with zero fraction is positive. The sign of a zero 
fraction resulting from other operations is established 
by the rules of algebra from the operand signs. 

Nortnallzation 

A quantity can be represented with the greatest pre- 
cision by a floating-point number of given fraction 
length when that number is normalized. A normalized 
floating-point number has a nonzero high-order hex- 
adecimal fraction digit. If one or more high-order 
fraction digits are zero, the number is said to be un- 
normalized. The process of normalization consists of 
shifting the fraction left until the high-order hexadeci- 
mal digit is nonzero and reducing the characteristic by 
the number of hexadecimal digits shifted. A zero frac- 
tion can not be normalized, and its associated char- 
acteristic therefore remains unchanged when normal- 
ization is called for. 

Normalization usually takes place when the inter- 
mediate arithmetic result is changed to the final result. 
This function is called postnormalization. In perform- 
ing multiplication and division, the operands are 
normalized prior to the arithmetic process. This func- 
tion is called prenormalization. 

Floating-point operations may be performed with 
or without normalization. Most operations are per- 
formed in only one of these two ways. Addition and 
subtraction may be specified either way. 

When an operation is performed without normaliza- 
tion, high-order zeros in the result fraction are not 
eliminated. The result may or may not be normalized, 
depending upon the original operands. 

In both normalized and unnormalized operations, 
the initial operands need not be in normalized form. 
Also, intermediate fraction results are shifted right 



when an overflow occurs, and the intermediate fraction 
result is truncated to the final result length after the 
shifting, if any. 

Programming Note 

Since normalization applies to hexadecimal digits, the 

three high-order bits of a normalized number may be 

zero. 



Condition Code 

The results of floating-point sign-control, add, sub- 
tract, and compare operations are used to set the con- 
dition code. Multiplication, division, loading, and 
storing leave the code unchanged. The condition code 
can be used for decision-making by subsequent 
branch-on-condition instructions. 

The condition code can be set to reflect two types 
of results for floating-point arithmetic. For most opera- 
tions, the states 0, 1, or 2 indicate the content of the 
result register is zero, less than zero, or greater than 
zero. A zero result is indicated whenever the result 
fraction is zero, including a forced zero. State 3 is used 
when the exponent of the result overflows. 

For comparison, the states 0, 1, or 2 indicate that the 
first operand is equal, low, or high. 

CONDITION CODE SETTING FOR FLOATING-POINT ARITHMEldC 
12 3 

Add Normalized s/l zero < zero > zero overflow 

Add Unnormalized s/l zero < zero > zero overflow 

Compare s/l equal low high 

Load and Test s/l zero < zero > zero 

Load Complement s/l zero < zero > zero 

Load Negative s/l zero < zero 

Load Positive s/l zero ~ > zero 

Subtract 

Normalized s/l zero < zero > zero overflow 
Subtract 

Unnormalized s/l zero < zero > zero overflow 

Instruction Format 

Floating-point instructions use the following two 
formats: 

RR Format 



Op Code 


«i 


h 
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RX Format 



Op Code 


«i 


><2 


^2 


°2 
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In these formats, Ri designates the address of a float- 
ing-point register. The contents of this register will be 
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called the first operand. The second operand location 
is defined differently for two formats. 

In the BB format, the R2 field specifies the address 
of a floating-point register containing the second op- 
erand. The same register may be specified for the first 
and second operand. 

In the RX format, the contents of the general register 
specified by X2 and B2 are added to the content of the 
D2 field to form an address designating the location of 
the second operand. 

A zero in an X2 or B2 field indicates the absence of 
the corresponding address component. 

The register address specified by the Ri and R2 
fields should be 0, 2, 4 or 6. Otherwise, a specification 
exeception is recognized, and a program interruption 
is caused. 

The storage address of the second operand should 
designate word boundaries for short operands and 
double-word boundaries for long operands. Otherwise, 
a specification exception is recognized, and a program 
interruption is caused. 

Results replace the first operand, except for the stor- 
ing operations, where the second operand is replaced. 

Except for the storing of the final result, the contents 
of all floating-point or general registers and storage 
locations participating in the addressing or execution 
part of an operation remain unchanged. 

The floating-point instructions are the only instruc- 
tions using the floating-point registers. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction. For a register-to- 
register operation using load (short), for example, 
LER is the mnemonic and Ri, R2 the operand desig- 
nation. 



Instructions 

The floating-point arithmetic instructions and their 
mnemonics, formats, and operation codes follow. All 
operations can be specified in short and long precision 
and are part of the floating-point feature. The follow- 
ing table indicates when normalization occurs, when 
the condition code is set, and the exceptions in oper- 
and designations, data, or results that cause a program 
interruption. 



MNEMONIC 



TYPE 



Load (Long) 
Load (Long) 
Load (Short) 
Load (Short) 
Load and Test 
(Long) 



LDR RR F 

LD RX F 

LER RR F 

LE RX F 

LTDR RR F,C 



EXCEPTIONS CODE 

S 28 

P,A,S 68 

S 38 

P,A,S 78 

S 22 



NAME MNEMONIC TYPE 

Load and Test 

(Short) LTER RR F,C 
Load Complement 

(Long) LCDR RR F,C 
Load Complement 

(Short) LCER RR F,C 

Load Positive (Long) LPDR RR F,C 

Load Positive (Short) LPER RR F,C 

Load Negative (Long) LNDR RR F,C 

Load Negative (Short) LNER RR F,C 
Add Normalized 

(Long) ADR RR F,C 
Add Normalized 

(Long) AD RX F,C 
Add Normalized 

(Short) AER RR F,C 
Add Normalized 

(Short) AE RX F,C 
Add Unnormalized 

(Long) AWR RR F,C 
Add Unnormalized 

(Long) AW RX F,C 
Add Unnormalized 

(Short) AUR RR F,C 
Add Unnormalized 

(Short) AU RX F,C 
Subtract Normalized 

(Long) SDR RR F,C 
Subtract Normalized 

(Long) SD RX F,C 
Subtract Normalized 

(Short) SER RR F,C 
Subtract Normalized 

(Short) SE RX F,C 
Subtract Unnorm- 
alized (Long) SWR RR F,C 
Subtract Unnorm- 
alized (Long) SW RX F,C 
Subtract Unnorm- 
alized (Short) SUR RR F,C 
Subtract Unnorm- 
alized (Short) SU RX F,C 
Compare (Long) CDR RR F,C 
Compare (Long) CD RX F,C 
Compare (Short) CER RR F,C 
Compare (Short) CE RX F,C 
Halve (Long) HDR RR F 
Halve (Short) HER RR F 
Multiply (Long) MDR RR F 
Multiply (Long) MD RX F 
Multiply (Short) MER RR F 
Multiply (Short) ME RX F 
Divide (Long) DDR RR F 
Divide (Long) DD RX F 
Divide (Short) DER RR F 
Divide (Short) DE RX F 
Store (Long) STD RX F 
Store (Short) STE RX F 



A Addressing exception 

C Condition code is set 

E Exponent-overflow exception 

F Floating-point feature 

FK Floating-point divide exception 

LS Significance exception 

P Protection exception 

S Specification exception 

U Exponent-underflow exception 



EXCEPTIONS CODE 

S 32 

S 23 

S 33 

S 20 

S 30 

S 21 

S 31 

S,U,E,LS 2A 

P,A,S,U,E,LS 6A 

S,U,E,LS 3A 

P,A,S,U,E,LS 7A 

S, E,LS 2E 

P,A,S, E,LS 6E 

S, E,LS 3E 

P,A,S, E,LS 7E 

S,U,E,LS 2B 

P,A,S,U,E,LS 6B 

S,U,E,LS 3B 

P,A,S,U,E,LS 7B 

S, E,LS 2F 

P,A,S, E,LS 6F 

S, E,LS 3F 

P,A,S, E,LS 7F 

S 29 

P,A,S 69 

S 39 

P,A,S 79 

S 24 

S 34 

S,U,E 2C 

P,A,S,U,E 6C 

S,U,E 3C 

P,A,S,U,E 7C 

S,U,E,FK 2D 

P,A.S,U,E,FK 6D 

S,U,E,FK 3D 

P,A,S,U.E,FK 7D 

P,A,S 60 

P,A,S 70 
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Load 



[RR, Short Operands] 



38 


^ 


h 



LE Ri,D2(X2,B2) 



n 12 15 

[RX, Short Operatrds] 
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LDR Rt,R2 [RR, Long Operands] 



28 


^ 


"2 
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LD Ri, 02(^2, B2) [RX, Long Operands] 



68 


«1 


^2 


h 


°2 
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The second operand is placed in the first operand 
location. 

The second operand is not changed. In short-preci- 
sion the low-order half of the result register remains 
unchanged. Exponent overflow, exponent underflow, 
or lost significance cannot occur. 

Condition Code: The code remains unchanged. 
Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by le and ld only) 
Addressing (le, id only) 
Specification 

Load and Test 

LTER Ri, R2 [RR, Short Operands] 



32 


^1 


h 



7 8 11 12 15 

LTDR Rj, R2 [RR, Long Operands] 



22 


^1 


R2 



7 8 1112 15 

The second operand is placed in the first operand 
location, and its sign and magnitude determine the 
condition code. 

The second operand is not changed. In short-preci- 
sion the low-order half of the result register remains 
unchanged and is not tested. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 - 



Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled ) 
Specification 

Programming Note 

When the same register is specified as first and second 
operand location, the operation is equivalent to a test 
without data movement. 



Load Complement 

LCER Ri, R2 [RR, Short Operands] 



33 
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LCDR Rj, R2 [RR, Long Operands] 
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«2 
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The second operand is placed in the first operand 
location with the sign changed to the opposite value. 

The sign bit of the second operand is inverted, while 
characteristic and fraction are not changed. In short- 
precision the low-order half of the result register re- 
mains unchanged and is not tested. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 - 

Program Interruptions: 
Operation (if floating-point feature is not; in- 
stalled) 
Specification 



Load Positive 

LPER Rj, R2 [RR, Short Operands] 



30 
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R2 
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LPDR Ri,R2 



[RR, Long Operands] 



20 


^1 


R2 
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The second operand is placed in the first operand 
location with the sign made plus. 
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The sign bit of the second operand is made zeto, 
while characteristic and fraction are not changed. In 
short-precision, the low-order half of the result register 
remains unchanged and is not tested. 

Resulting Condition Code: 

Result fraction is zero 

1 - 

2 Result is greater than zero 

3 - 

Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled) 
Specification 

Load Negative 

INER Ri, R2 {RR, Short Operands] 



ADR Ri, R2 [RR, Long Operands] 



31 
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h 



U 12 



LNDR Ri, R2 



[RR, Long Operands] 



21 


^1 


R2 



11 12 

The second operand is placed in the first operand 
location with the sign made minus. 

The sign bit of the second operand is made one, 
even if the fraction is zero. Characteristic and fraction 
are not changed. In short-precision, the low-order half 
of the result register remains unchanged and is not 
tested. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 - 

3 -- 

Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled) 
Specification 

Add Normalized 

AER Ri, R2 [RR, Short Operands] 
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«1 


R2 



11 12 



AE R„D2(X2,B2) 



[RX, Short Operands] 
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AD Ri,D2(X2,B2) 



[RX, Long Operands] 
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X2 
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°2 
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The second operand is added to the first operand, and 
the normalized sum is placed in the first operand 
location. 

In short-precision the low-order halves of the float- 
ing-point registers are ignored and remain unchanged. 

Addition of two floating-point numbers consists of a 
characteristic comparison and a fraction addition. The 
characteristics of the two operands are compared, and 
the fraction with the smaller characteristic is right- 
shifted; its characteristic is increased by one for each 
hexadecimal digit of shift, until the two characteristics 
agree. The fractions are then added algebraically to 
form an intermediate sum. If an overflow carry occurs, 
the intermediate sum is right-shifted one digit, and the 
characteristic is increased by one. If this increase 
causes a characteristic overflow, an exponent-overflow 
exception is signaled, and a program interruption 
occurs. 

The short intermediate sum consists of seven hex- 
adecimal digits and possible carry. The low-order 
digit is a guard digit retained from the fraction which 
is shifted right. Only one guard digit participates in 
the fraction addition. The guard digit is zero if no shift 
occurs. The long intermediate sum consists of 14 hex- 
adecimal digits and a possible carry. No guard digit 
is retained. 

After the addition, the intermediate sum is left- 
shifted as necessary to form a normalized fraction; 
vacated low-order digit positions are filled with zeros 
and the characteristic is reduced by the amount of 
shift. 

If normalization causes the characteristic to under- 
flow, characteristic and fraction are made zero, an 
exponent-underflow exception exists, and a program 
interruption occurs if the corresponding mask bit is 
one. If no left shift takes place the intermediate sum 
is truncated to the proper fraction length. 

When the intermediate sum is zero and the signifi- 
cance mask bit is one, a significance exception exists, 
and a program interruption takes place. No normal- 
ization occurs; the intermediate sum characteristic 
remains unchanged. When the intermediate sum is 
zero and the significance mask bit is zero, the program 
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interruption for the significance exception does not 
occur; rather, the characteristic is made zero, yielding 
a true zero result. Exponent underflow does not occur 
for a zero fraction. 

The sign of the sum is derived by the rules of 
algebra. The sign of a sum with zero result fraction 
is always positive. 

Resulting Coruiition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Result exponent overflows 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by ae and ad only) 
Addressing (ae and ad only) 
Specification 
Significance 
Exponent overflow 
Exponent underflow 

Programming Note 

Interchanging the two operands in a floating-point 
addition does not affect the value of the sum. 

Add Un normalized 

AUR Ri, R^ [RR, Short Operands] 



3E 


«1 


h 



7 8 1112 15 



AU Ri, DzfXz, Bz) [RX, Short Operands] 



7E 


"l 


^2 


^2 


"2 



7 8 1112 1516 1920 



AWR Rx, Rs [RR, Long Operands] 



2E 


^1 


h 



7 8 11 T2 15 



AW Ri,02(X2,B2) 



[RX, Long Operands] 



6E 


h 


\ 


h 


°2 



7 8 11 12 15 16 19 20 



After the addition the intermediate sum is truncated 
to the proper fraction length. 

When the resulting fraction is zero and the signifi- 
cance mask bit is one, a significance exception exists 
and a program interruption takes place. When the 
resulting fraction is zero and the significance mask 
bit is zero, the program interruption for the signifi- 
cance exception does not occur; rather, the character- 
istic is made zero, yielding a true zero result. 

Leading zeros in the result are not eliminated by 
normalization, and an exponent underflow cannot 
occur. 

The sign of the sum is derived by the rules of 
algebra. The sign of a sum with zero result fraction is 
always positive. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greatCT th?in zero 

3 Result exponent overflows 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by au and aw only) 
Addressing (au and aw only) 
Specification 
Significance 
Exponent overflow 

Subtract Normalized 

SER Ri, R2 [RR, Short Operands] 



3B 


^ 


Rj 



SE Ri,D2(Xz,B2) 



[RX, Short Operands] 



7B 



Ri Xj ^2 



7 8 11 12 15 16 1920 



SDR Ri, R2 [RR, Long Operands] 



2B 


"1 


"2 



7 8 1112 15 



SD Rx, DziXz, B2) RX, Long Operands] 



6B 



R^ X2 ^2 



7 8 11 12 1516 1920 



The second operand is added to the first operand, and 
the unnormaiized sum is placed in the first operand 
location. 

In short-precision, the low-order halves of the float- 
ing-point registers are ignored and remain unchanged. 



The second operand is subtracted from the first op- 
erand, and the normalized difference is placed in the 
first operand location. 

In short-precision, the low-order halves of the float- 
ing-point registers are ignored and remain unchanged. 
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The SUBTRACT NORMAUZED is Similar to ADD NORMAL- 
IZED, except that the sign of the second operand is 
inverted before addition. 

The sign of the diflFerence is derived by the rules of 
algebra. The sign of a difference with zero result 
fraction is always positive. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Result exponent overflows 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by se and so only) 
Addressing (sd and se only) 
Specification 
Significance 
Exponent overflow 
Exponent underflow 



Subtract Unnormalized 

SUR Rul^2 [l^f^f Sf^ort Operands] 



3F 


"l 


Rj 



7 8 1112 15 



5U Ri, DafXg, Bz) [RX, Short Operands] 



7F 


"l 


^2 


«2 


^2 



7 6 1112 1516 1920 



SWR Ri, R2 [RR, Long Operands] 



2F 


^r 


"2 



7 S 11 12 15 



SW Ri,D2(X2,B2) [RX, Long Operands] 



6F 


"1 


>«2 


h 


''2 



7 8 1112 15 16 1920 



The second operand is subtracted from the first op- 
erand, and the unnormalized difference is placed in 
the first operand location. 

In short-precision, the low-order halves of the float- 
ing-point register are ignored and remain unchanged. 

The SUBTRACT UNNORMALIZED is similar to add UN- 
normalized, except for the inversion of the sign of the 
second operand before addition. 



The sign of the difference is derived by the rules of 
algebra. The sign of a difference with zero result 
fraction is always positive. 

Resulting Condition Code: 

Result fraction is zero 

1 Result is less than zero 

2 Result is greater than zero 

3 Result exponent overflows 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by su and sw only) 
Addressing (sw and su only) 
Specification 
Significance 
Exponent overflow 



Compare 
CER RuRz 



\RR, Short Operands] 



39 


«1 


Rj 



11 12 15 



CE Ri, Dz(X2, B2) [RX, Short Operands] 



79 


h 


X2 


»2 


"2 



7 8 1112 1516 19 20 



COR Rj, R2 [RR, Long Operands] 



29 


«1 


Rj 



7 8 1112 15 



CD RuD2(X2,B2) 



[RX, Long Operands] 



49 


''t 


^2 


^2 


■^2 



1516 19 20 



The first operand is compared with the second op- 
erand, and the condition code indicates the result. 

In short-precision, the low-order halves of the float- 
ing-point registers are ignored. 

Comparison is algebraic, taking into account the 
sign, fraction, and exponent of each number. An expo- 
nent inequality is not decisive for magnitude determi- 
nation since the fractions may have different numbers 
of leading zeros. An equality is established by follow- 
ing the rules for normalized floating-point subtraction. 
When the intermediate sum, including a possible 
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guard digit, is zero, the operands are equal. Neither 
operand is changed as a result of the operation. 

Exponent overflow, exponent underflow, or lost sig- 
nificance cannot occur. 

Resulting Condition Code: 

Operands are equal 

1 First operand is low 

2 First operand is high 

3 -- 

Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by ce and cd only) 
Addressing (cd and ce only) 
Specification 



Programming Note 

Numbers with zero fraction compare equal even when 
they differ in sign or characteristic. 



Halve 
rfcK R^, Kg 



[RR, Short Operands] 



34 


^1 


"2 



HDR Ri, Rz 



\RR, Long Operands] 



24 


«1 


"2 



The second operand is divided by two, and the 
quotient is placed in the first operand location. 

In short-precision, the low-order half of the result 
register remains unchanged. 

The operation shifts the fraction right one bit; the 
sign and characteristic are not changed. No normaliza- 
tion or test for zero fraction takes place. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Specification 



Programming Note 

The halve operation differs from a divide operation 
with the number two as divisor in the absence of pre- 
normalization and postnormalization and in the ab- 
sence of a zero-fraction test. 



Multiply 

MER R^, R2 [RR, Short Operands] 



3C 


^1 


"2 



7 8 1112 15 

ME Ri, D2(X2, B2) [RX, Short Operands] 



7C 


h 


Xj 


»2 


=^2 



MDR Ri, Re 



7 8 1112 15 16 1920 



[RR, Long Operands] 



2C 


^1 


«2 



MD Ru D2(X2, B2) 



[RX, Long Operands] 



6C 



R, 



The normalized product of multiplier ( the second op- 
erand) and multiplicand (the first operand) replaces 
the multiplicand. 

The multiplication of two floating-point numbers 
consists of a characteristic addition and a fraction 
multiplication. The sum of the characteristics less 64 is 
used as the characteristic of an intermediate product. 
The sign of the product is determined by the rules of 
algebra. 

The product fraction is normalized by prenormaliz- 
ing the operands and postnormalizing the intermediate 
product, if necessary. The intermediate product char- 
acteristic is reduced by the number of left-shifts. For 
long operands, the intermediate product fraction is 
truncated before the left-shifting, if any. For short 
operands ( six-digit fractions ) , the product fraction has 
the full 14 digits of the long format, and the two low- 
order fraction digits are accordingly always zero. 

Exponent overflow occurs if the final product char- 
acteristic exceeds 127. The operation is terminated, 
and a program interruption occurs. The overflow ex- 
ception does not occur for an intermediate product 
characteristic exceeding 127 when the final character- 
istic is brought within range because of normalization. 

Exponent underflow occurs if the final product char- 
acteristic is less than zero. The characteristic and 
fraction are made zero, and a program interruption 
occurs if the corresponding mask bit is one. Underflow 
is not signaled when an operand's characteristic be- 
comes less than zero during prenormalization, and the 
correct characteristic and fraction value are used in 
the multiplication. 

When all 14 result fraction digits are zero, the prod- 
uct sign and characteristic are made zero, yielding a 
true zero result without exponent underflow and ex- 
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ponent overflow causing a program interruption. The 
program interruption for lost significance is never 
taken for multiplication. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by me and md only) 
Addressing ( md and me only) 
Specification 
Exponent overflow 
Exponent underflow 

Programming Note 

Interchanging the two operands in a floating-point 
multiplication does not affect the value of the product. 
Because of the truncation of intermediate results to 
14 hexadecimal fraction digits and the introduction 
of a low-order zero in a subsequent left shift, if any, 
the low-order digit in the result of a long-precision 
multiplication of normalized operands is not neces- 
sarily significant. The truncation error affects only the 
low-order fraction digit, and the effect of the trunca- 
tion is predictable. 

Divide 

DER Ri, R2 [RR, Short Operands] 



3D 


«, 


"2 



7 8 11 12 15 

DE Ri, D2(X2, B2) [RX, Short Operands] 



7D 


«1 


^2 


^2 


°2 



7 8 11 12 1516 1920 



DDR Ri, R2 [RR, Long Operands] 



2D 


«1 


h 



7 8 1112 15 



DD Ri, D2(X2, B2) 



[RX, Long Operands] 



6D 


^ 


X2 


^2 


'>2 



7 8 1112 1516 1920 



The dividend (the first operand) is divided by the 
divisor (the second operand) and replaced by the 
quotient. No remainder is preserved. 



In short-precision, the low-order halves of the float- 
ing-point register are ignored and remain unchanged. 

A floating-point division consists of a characteristic 
subtraction and a fraction division. The difference be- 
tween the dividend and divisor characteristics plus 
64 is used as an intermediate quotient characteristic. 
The sign of the quotient is determined by the rules of 
algebra. 

The quotient fraction is normalized by prenormaliz- 
ing the operands. Postnormalizing the intermediate 
quotient is never necessary, but a right-shift may be 
called for. The intermediate-quotient characteristic is 
adjusted for the shifts. All dividend fraction digits 
participate in forming the quotient, even if the normal- 
ized dividend fraction is larger than the normalized 
divisor fraction. The quotient fraction is truncated to 
the desired number of digits. 

A program interruption for exponent overflow oc- 
curs when the final-quotient characteristic exceeds 127. 
The operation is terminated. 

A program interruption for exponent underflow oc- 
curs if the final-quotient characteristic is less than 
zero. The characteristic, sign, and fraction are made 
zero, and the interruption occurs if the corresponding 
mask bit is one. Underflow is not signaled for the 
intermediate quotient or for the operand character- 
istics during prenormalization. 

When division by a divisor with zero fraction is at- 
tempted, the operation is suppressed. The dividend 
remains unchanged, and a program interruption for 
floating-point divide occurs. When the dividend frac- 
tion is zero, the quotient fraction will be zero. The 
quotient sign and characteristic are made zero, yield- 
ing a true zero result without taking the program 
interruption for exponent underflow and exponent 
overflow. The program interruption for significance is 
never taken for division. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Operation (if floating-point feature is not in- 
stalled) 
Protection (fetch violation by de and dd only) 
Addressing (dd and de only) 
Specification 
Exponent overflow 
Exponent underflow 
Floating-point divide 
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Store 

STE Rj, DsfXg, B2) [RX, Short Operands] 



70 



7 8 1112 1516 1920 



STD Ri,D2(X2,B2) 



[RX, Long Operands] 



60 


^1 


X2 


'2 


°2 



II 12 15 16 



The first operand is stored at the second operand 
location. 

In short-precision, the low-order half of the first op- 
erand register is ignored. The first operand remains 
unchanged. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation (if floating-point feature is not in- 
stalled) 
Addressing 

Protection (store violation) 
Specification 



Floating-Point Arithmetic Exceptions 

Exceptional operation codes, operand designations, 
data, or results cause a program interruption. When 
the interruption occurs, the current psw is stored as 
an old PSW, and a new psw is obtained. The interrup- 
tion code in the old psw identifies the cause of the 
interruption. The following exceptions cause a pro- 
gram interruption in floating-point arithmetic. 

Operation: The floating-point feature is not installed, 
and an attempt is made to execute a floating-point in- 
struction. The instruction is suppressed. The condition 
code and data in registers and storage remain un- 
changed. 

Protection: The key of an operand in storage does 
not match the protection key in the psw. The opera- 
tion is suppressed on a store violation. Therefore, the 
condition code and data in registers remain un- 
changed. On a fetch violation, the operation is ter- 
minated; result data and the condition code are un- 
predictable. 



Addressing: An address designates an operand loca- 
tion outside the available storage for the installed sys- 
tem. In most cases, the operation is terminated. The 
result data and the condition code, if affected, are un- 
predictable and should not be used for further com- 
putation. The exception is store ( ste and std ) , which 
is suppressed. 

Specification: A short operand is not located on a 
32-bit boundary or a long operand is not located on a 
64-bit boundary; or, a floating-point register address 
other than 0, 2, 4, or 6 is specified. The instruction is 
suppressed. Therefore, the condition code and data 
in registers and storage remain unchanged. The ad- 
dress restrictions do not apply to the components from 
which an address is generated — the content of the 
D2 field and the contents of the registers specified by 
X2 and B2. 

Exponent Overflow: The result exponent of an addi- 
tion, subtraction, multiplication, or division overflows, 
and the result fraction is not zero. The operation is 
terminated; the result data are unpredictable and 
should not be used for further computation. The con- 
dition code is set to 3 for addition and subtraction and 
remains unchanged for multiplication and division. 

Exponent Underflow: The result of an addition, sub- 
traction, multiplication, or division underflows, and the 
result fraction is not zero. A program interruption oc- 
curs if the exponent-underflow mask bit ( psw bit 38 ) 
is one. The operation is completed by replacing the 
result with a true zero. The condition code is set to 
for addition and subtraction and remains unchanged 
for multiplication and division. The state of the mask 
bit does not affect the result. 

Significance: The result fraction of an addition or 
subtraction is zero. A program interruption occurs if 
the significance mask bit ( PSW bit 39 ) is one. The mask 
bit affects also the result of the operation. When the 
significance mask bit is a zero, the operation is com- 
pleted by replacing the result with a true zero. When 
the significance mask bit is one, the operation is com- 
pleted without further change to the characteristic of 
the result. In either case, the condition code is set to 0. 

Floating-Point Divide: Division by a number with 
zero fraction is attempted. The division is suppressed; 
therefore, the condition code and data in registers and 
storage remain unchanged. 
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Logical Operations 



A set of instructions is provided for the logical ma- 
nipulation of data. Generally, the operands are treated 
as eight-bit bytes. In a few cases the left or right four 
bits of a byte are treated separately or operands are 
shifted a bit at a time. The operands are either in 
storage or in general registers. Some operands are in- 
troduced from the instruction stream. 

Processing of data in storage proceeds left to right 
through fields which may start at any byte position. In 
the general registers, the processing, as a rule, in- 
volves the entire register contents. 

Except for the editing instructions, data are not 
treated as numbers. Editing provides a transformation 
from packed decimal digits to alphanumeric charac- 
ters. 

The set of logical operations includes moving, com- 
paring, bit connecting, bit testing, translating, editing, 
and shift operations. All logical operations other than 
editing are part of the standard instruction set. Edit- 
ing instructions are part of the decimal feature. 

The condition code is set as a result of all logical 
comparing, connecting, testing, and editing operations. 



Data Format 

Data reside in general registers or in storage or are 
introduced from the instruction stream. The data size 
may be a single or double word, a single character, or 
variable in length. When two operands participate 
they have equal length, except in the editing instruc- 
tions. 



Fixed-Lengfh Logical Information 



Logical Data 



Data in general registers normally occupy all 32 bits. 
Bits are treated uniformly, and no distinction is made 
between sign and numeric bits. In a few operations, 
only the low-order eight bits of a register participate, 
leaving the remaining 24 bits unchanged. In some 
shift operations, 64 bits of an even/odd pair of regis- 
ters participate. 



The LOAD ADDBEss iutroduccs a 24-bit address into 
a general register. The high-order eight bits of the 
register are made zero. 

In storage-to-register operations, the storage data 
occupy either a word of 32 bits or a byte of eight bits. 
The word must be located on word boundaries, that 
is, its address must have the two low-order bits zero. 

Variable-Length Logical Information 



Character 


Character 



Character 



In storage-to-storage operations, data have a variable 
field-length format, starting at any byte address and 
continuing for up to a total of 256 bytes. Processing 
is left to right. 

Operations introducing data from the instruction 
stream into storage, as immediate data, are restricted 
to an eight-bit byte. Only one byte is introduced from 
the instruction stream, and only one byte in storage 
participates. 

Use of general register 1 is implied in translate 
AND TEST and EDIT AND MARK. A 24-bit address may be 
placed in this register during these operations. The 
TRANSLATE AND TEST also implies general register 2. 
The low-order eight bits of register 2 may be replaced 
by a function byte during a translate-and-test oper- 
ation. 

Editing requires a packed decimal field and gen- 
erates zoned decimal digits. The digits, signs, and 
zones are recognized and generated as for decimal 
arithmetic. Otherwise, no internal data structure is re- 
quired, and all bit configurations are considered valid. 

The translating operations use a list of arbitrary 
values. A list provides a relation between an argument 
(the quantity used to reference the list) and the 
function (the content of the location related to the 
argument). The purpose of the translation may be to 
convert data from one code to another code or to per- 
form a control function. 

A list is specified by an initial address — the address 
designating the leftmost byte location of the list. The 
byte from the operand to be translated is the argu- 
ment. The actual address used to address the list is 
obtained by adding the argument to the low-order po- 
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sitions of the initial address. As a consequence, the list 
contains 256 eight-bit function bytes. In cases where 
it is known that not all eight-bit argument values will 
occur, it may be possible to reduce the size of the list. 
In a storage-to-storage operation, the operand fields 
may be defined in such a way that they overlap. The 
effect of this overlap depends upon the operation. 
When the operands remain unchanged, as in compare 
or TKANSLATE AND TEST, Overlapping does not affect 
the execution of the operation. In the case of move,, 
EDIT, and translate;, one operand is replaced by new 
data, and the execution of the operation may be af- 
fected by the amount of overlap and the manner in 
which data are fetched or stored. For purposes of 
evaluating the effect of overlapped operands, consider 
that data are handled one eight-bit byte at a time. All 
overlapping fields are considered valid but, in editing, 
overlapping fields give unpredictable results. 



Instruction Format 

Logical instructions use the following five formats: 



RR format 



Op Code 


«i 


Rj 



7 8 11 12 15 



RX Format 



Op Code 



7 8 11 12 15 16 1920 



RS Format 



Op Code 



7 8 11 12 15 16 1920 



SI Format 



Condition Code 

The results of most logical operations are used to set 
the condition code in the psw. The load address, in- 
sert CHARACTERS, STORE CHARACTER, TRANSLATE, and 

the moving and shift operations leave this code un- 
changed. The condition code can be used for decision- 
making by subsequent branch-on-condition instruc- 
tions. 

The condition code can be set to reflect five types 
of results for logical operations: For compare logical 
the states 0, 1, or 2 indicate that the first operand is 
equal, low, or high. 

For the logical-connectives, the states or 1 indi- 
cate a zero or nonzero result field. 

For TiiiST under mask, the states 0, 1, or 3 indicate 
that the selected bits are all-zero, mixed zero and one, 
or all-one. 

For translate and test, the states 0, 1, or 2 indi- 
cate an all-zero function byte, a nonzero function byte 
with the operand incompletely tested, or a last func- 
tion byte nonzero. 

For editing the states 0, 1, or 2 indicate a zero, less 
than zero, or greater than zero content of the last re- 
sult field. 

CONDITION CODE SETTING FOR LOGICAL OPERATIONS 



And 


zero 


not zero 


— 


Compare Logical 


equal 


low 


high 


Edit 


zero 


< zero 


> zero 


Edit and Mark 


zero 


< zero 


> zero 


Exclusive Or 


zero 


not zero 


— 


Or 


zero 


not zero 


— 


Test Under Mask 


zero 


mixed 


— 


Translate and Test 


zero 


incomplete 


complel 



Op Code 



1516 1920 



SS Format 



Op Code 



^[MaJI^ 



15 16 19 20 31 32 35 36 



In the RR, RX, and RS formats, the content of the regis- 
ter specified by Ri is called the first operand. 

In the si and ss formats, the content of the general 
register specified by Bi is added to the content of the 
Di field to form an address. This address designates 
the leftmost byte of the first operand field. The num- 
ber of bytes to the right of this first byte is specified 
by the L field in the ss format. In the si format the 
operand size is one byte. 

In the RR format, the R2 field specifies the register 
containing the second operand. The same register may 
be specified for the first and second operand. 

In the RX format, the contents of the general regis- 
ters specified by the X2 and B2 fields are added to the 
content of the D2 field to form the address of the sec- 
ond operand. 

In the RS format, used for shift operations, the con- 
tent of the general register specified by the B2 field 
is added to the content of the D2 field. This sum is not 
used as an address but specifies the number of bits of 
the shift. The R3 field is ignored in the shift oper- 
ations. 

In the SI format, the second operand is the eight-bit 
immediate data field, I2, of the instruction. 
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In the ss format, the content of the general register 
specified by B2 is added to the content of the D2 field 
to form the address of the second operand. The sec- 
ond operand field has the same length as the first op- 
erand field. 

A zero in any of the X2, Bi, or B2 fields indicates 
the absence of the corresponding address or shift- 
amount component. An instruction can specify the 
same general register both for address modification 
and for operand location. Address modification is al- 
ways completed prior to operation execution. 

Results replace the first operand, except in store 
CHARACTER, where the result replaces the second op- 
erand. A variable-length result is never stored outside 
the field specified by the address and length. 

The contents of all general registers and storage lo- 
cations participating in the addressing or execution of 
an operation generally remain unchanged. Exceptions 
are the result locations, general register 1 in edit and 
MARK, and general registers 1 and 2 in translate and 
test. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction: For move numerics, 
for example, mvn is the mnemonic and Di (L, Bi), 
D2 (B2) the operand designation. 



Instructions 

The logical instructions, their mnemonics, formats, and 
operation codes follow. The table also indicates when 
the condition code is set and the exceptions in operand 
designations, data, or results that cause a program in- 
terruption. 



NAME 


MNEMONIC 


TYPE 


EXCEPTIONS 


CODE 


Move 


MVI 


SI 




P,A 


92 


Move 


MVC 


SS 




P,A 


D2 


Move Numerics 


MVN 


ss 




P,A 


Dl 


Move Zones 


MVZ 


ss 




P,A 


D3 


Compare Logical 


CLR 


RR 


C 




15 


Compare Logical 


CL 


RX 


C 


P,A,S 


55 


Compare Logical 


CLI 


SI 


C 


P,A 


95 


Compare Logical 


CLC 


SS 


C 


P,A 


D5 


AND 


NR 


RR 


C 




14 


AND 


N 


RX 


C 


P,A,S 


54 


AND 


NI 


SI 


C 


P,A 


94 


AND 


NC 


SS 


C 


P,A 


D4 


OR 


OR 


RR 


C 




16 


OR 





RX 


C 


P,A,S 


56 


OR 


01 


SI 


C 


P,A 


96 


OR 


OC 


SS 


C 


P,A 


D6 


Exclusive OR 


XR 


RR 


C 




17 


Exclusive OR 


X 


RX 


C 


P,A,S 


57 


Exclusive OR 


XI 


SI 


C 


P,A 


97 



NAME MNEMONIC 


TYPE 


EXCEPTIONS 


CODE 


Exclusive OR XC 


SS 


C 


P,A 


D7 


Test Under Mask TM 


SI 


c 


P,A 


91 


Insert Character IC 


RX 




P,A 


43 


Store Character STC 


RX 




P,A 


42 


Load Address LA 


RX 






41 


Translate TR 


SS 




P,A 


DC 


Translate and Test TRT 


SS 


c 


P,A 


DD 


Edit ED 


SS 


T,C 


P,A, D 


DE 


Edit and Mark EDMK 


ss 


T,C 


P,A, D 


DF 


Shift Left Single 










Logical SLL 


RS 






89 


Shift Right Single 










Logical SRL 


RS 






88 


Shift Left Double 










Logical SLDL 


RS 




S 


8D 


Shift Right Double 










Logical SRDL 


RS 




S 


8C 


NOTES 










A Addressing exception 










C Condition code is set 










D Data exception 










P Protection exception 










S Specification exception 










T Decimal feature 











Programming Note 

The fixed-point loading and storing instructions also 

may be used for logical operations. 



Move 

MVI D,(BiKl2 [SI] 
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\ 


°^ 



15 16 1920 



MVC DJL, Bj), Do(Bo) 



[«] 



D2 I L \ ^^ I^^Dil B, |^}~5^ 



The second operand is placed in the first operand lo- 
cation. 

The ss format is used for a storage-to-storage move. 
The SI format introduces one 8-bit byte from the 
instruction stream. 

In storage-to-storage movement the fields may over- 
lap in any desired way. Movement is left to right 
through each field a byte at a time. 

The bytes to be moved are not changed or in- 
spected. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (store violation for mvi; store or fetch 

violation for mvc) 
Addressing 
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Programming Note 

It is possible to propagate one character through an 
entire field by having the first operand field start one 
character to the right of the second operand field. 



Move Numerics 

MVN Di(L, BiK D2(B2) 



[«] 



Di I L \ ^ if^'T^r^ 



The low-order four bits of each byte in the second op- 
erand field, the numerics, are placed in the low-order 
bit positions of the corresponding bytes in the first 
operand fields. 

The instruction is storage to storage. Movement is 
left to right through each field one byte at a time, and 
the fields may overlap in any desired way. 

The numerics are not changed or checked for validi- 
ty. The high-order four bits of each byte, the zones, 
remain unchanged in both operand fields. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (store or fetch violation) 
Addressing 



Move Zones 

MVZ Di(L,B,hD^lB,) [SS] 



D3 



1 



^{K120IZ 



15 16 19 20 31 32 35 36 47 



The high-order four bits of each byte in the second 
operand field, the zones, are placed in the high-order 
four bit positions of the corresponding bytes in the 
first operand field. 

The instruction is storage to storage. Movement is 
left to right through each field one byte at a time, and 
the fields may overlap in any desired way. 

The zones are not changed or checked for validity. 
The low-order four bits of each byte, the numerics, 
remain unchanged in both operand fields. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Protection (store or fetch violation) 
Addressing 



Compare Logical 

CLR Ri, R2 [RR] 



15 
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78 1112 15 

a Rt, D2(X2, B2) [RX] 
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The first operand is compared with the second oper- 
and, and the result is indicated in the condition code. 

The instructions allow comparisons that are register 
to register, storage to register, instruction to storage, 
and storage to storage. 

Comparison is binary, and all codes are valid. The 
operation proceeds left to right and ends as soon as an 
inequality is found or the end of the fields is reached. 
However, when part of an operand in clc is specified 
in an unavailable location, the operation may be termi- 
nated by the addressing exception, even though an 
inequality could have been found in a comparison of 
the available operand parts. 

Resulting Condition Code: 

Operands are equal 

1 First operand is low 

2 First operand is high 

3 ~ 

Program Interruptions: 

Protection (fetch violation for cl, cli, and clc 

only) 
Addressing (cl, cli, clc only) 
Specification (cl only) 

Programming Note 

The COMPARE LOGICAL is uniquc in treating all bits 
alike as part of an unsigned binary quantity. In vari- 
able-length operation, comparison is left to right and 
may extend to field lengths of 256 bytes. The operation 
may be used to compare unsigned packed decimal 
fields or alphameric information in any code that has 
a collating sequence based on ascending or descending 
binary values. For example, ebcdic has a collating se- 
quence based on ascending binary values. 
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AND 

NR R^, R2 [RR] 



O Ru D.JX2, B2) [R^] 



14 


^1 


R2 



7 8 1112 15 



N Ri,D,(X2,B2) [RX] 
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15 16 1920 



NC D,rt, B,^ DsfB^) [SS] 



D4 I L I °1 U{Pl| °2 |^P2 



15 16 1920 31 32 35 36 47 



The logical product (and) of the bits of the first and 
second operand is placed in the first operand location. 

Operands are treated as unstructured logical quan- 
tities, and the connective and is applied bit by bit. A 
bit position in the result is set to one if the correspond- 
ing bit positions in both operands contain a one; other- 
wise, the result bit is set to zero. All operands and 
results are valid. 

Resulting Condition Code: 

Result is zero 

1 Result not zero 

2 - 

3 - 

Program Interruptions: 

Protection (fetch violation only for N; store vio- 
lation only for ni; store or fetch violation for 

NC) 

Addressing (n, ni, nc only) 
Specification (n only) 

Programming Note 

The AND may be used to set a bit to zero. 



OR 

OR Ri, R2 



[RR] 
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^1 


R2 
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7 8 15 16 19 20 31 32 35 36 47 

The logical sum (or) of the bits of the first and sec- 
ond operand is placed in the first operand location. 

Operands are treated as unstructured logical quan- 
tities, and the connective inclusive or is appHed bit by 
bit. A bit position in the result is set to one if the cor- 
responding bit position in one or both operands con- 
tains a one; otherwise, the result bit is set to zero. All 
operands and results are valid. 

Resulting Condition Code: 

Result is zero 

1 Result not zero 

2 - 

3 - 

Program Interruptions: 

Protection (fetch violation only for o; store vio- 
lation only for oi; store or fetch violation for oc ) 
Addressing (o, oi, oc only) 
Specification (o only) 

Programming Note 

The OR may be used to set a bit to one. 

Exclusive OR 

XR R„ R2 [RR] 



u 


'^ 


R2 
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X Rj, D.JX2, B2) [RX] 
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The modulo-two sum (exclusive or) of the bits of the 
first and second operand is placed in the first operand 
location. 

Operands are treated as unstructured logical quanti- 
ties, and the connective exclusive or is applied bit by 
bit. A bit position in the result is set to one if the cor- 
responding bit positions in the two operands are un- 
like; otherwise, the result bit is set to zero. 

TTie instruction differs from and and or only in the 
connective applied. 

Resulting Condition Code: 

Result is zero 

1 Result not zero 

2 - 

3 - 

Program Interruptions: 

Protection (fetch violation only for x; store vio- 
lation only for xi; store or fetch violation for xc ) 
Addressing (x, xi, xc only) 
Specification (x only) 



Programming Notes 

The exclusive or may be used to invert a bit, an opera- 
tion particularly useful in testing and setting pro- 
grammed binary bit switches. 

Any field exclusive on'od with itself becomes all 
zeros. 

The sequence A exclusive OR'ed B, B exclusive OR'ed 
A, A exclusive OR'ed B results in the exchange of the 
contents of A and B without the use of an auxiliary 
buffer area. 



Test Under Mask 

TM D,(Bj), h [S'l 



91 


'2 


^ 


°1 



The state of the first operand bits selected by a mask 
is used to set the condition code. 

The byte of immediate data, I2, is used as an eight- 
bit mask. The bits of the mask are made to correspond 
one for one with the bits of the character in storage 
specified by the first operand address. 

A mask bit of one indicates that the storage bit is 
to be tested. When the mask bit is zero, the storage bit 
is ignored. When all storage bits thus selected are zero, 
the condition code is made 0. The code is also made 
when the mask is all-zero. When the selected bits 
are all-one, the code is made 3; otherwise, the code is 
made 1. The character in storage is not changed. 



Resulting Condition Code: 

Selected bits all-zero; mask is all-zero 

1 Selected bits mixed zero and one 

2 ~ 

3 Selected bits all-one 
Program Interruptions: 

Protection ( fetch violation ) 
Addressing 

Insert Character 

/C Ri,D2(X2,B,) [RX] 
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7 8 11 12 15 16 1920 



The eight-bit character at the second operand address 
is inserted into bit positions 24-31 of the register spe- 
cified as the first operand location. The remaining bits 
of the register remain unchanged. 

The instruction is storage to general register. The 
byte to be inserted is not changed or inspected. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection (fetch violation) 
Addressing 

Store Character 

STC Ri,D,(X2,Bs) [RX] 
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Bit positions 24-31 of the register designated as the 
first operand are placed at the second operand ad- 
dress. 

The instruction is general register to storage. The 
byte to be stored is not changed or inspected. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Protection (store violation) 
Addressing 

Load Address 

LA Ri, D^rXg, B2) [RX] 



41 



'1 



The address of the second operand is inserted in the 
low-order 24 bits of the general register specified by 
Ri. The remaining bits of the general register are 
made zero. No storage references for operands take 
place. 
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The address specified by the X2, B2, and D2 fields is 
inserted in bits 8-31 of the general register specified 
by Ri. Bits 0-7 are set to zero. The address is not in- 
spected for availability, protection, or resolution. 

The address computation follows the rules for ad- 
dress arithmetic. Any carries beyond the 24th bit are 
ignored. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 



Programming Note 

The same general register may be specified by the Ri, 
X2, and B2 instruction field, except that general regis- 
ter can be specified only by the Ri field. In this 
manner, it is possible to increment the low-order 24 
bits of a general register, other than 0, by the con- 
tents of the D2 field of the instruction. The register 
to be incremented should be specified by Ri and by 
either X2 (with B2 set to zero) or B2 (with X2 set to 
zero ) . 
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Translate 

TR Di(L,Bi), 02(82) [5S] 



DC 



^[snoca 



15 16 19 20 31 32 35 36 47 



The eight-bit bytes of the first operand are used as 
arguments to reference the list designated by the sec- 
ond operand address. Each eight-bit function byte se- 
lected from the list replaces the corresponding argu- 
ment in the first operand. 

The bytes of the first operand are selected one by 
one for translation, proceeding left to right. Each 
argument byte is added to the entire initial address, 
the second operand address, in the low-order bit po- 
sitions. The sum is used as the address of the function 
byte, which then replaces the original argument byte. 

All data are valid. The operation proceeds until the 
first operand field is exhausted. The list is not altered 
unless an overlap occurs. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Protection ( store or fetch violation ) 
Addressing 



Translate and Test 

TRT Di(L,Bi), 02(82) 



[S5] 



DD 



isrzoi 



31 32 35 36 



The eight-bit bytes of the first operand are used as 
arguments to reference the list designated by the sec- 
ond operand address. Each eight-bit function byte 
thus selected from the list is used to determine the 
continuation of the operation. When the, function byte 
is a zero, the operation proceeds by fetching and 
translating the next argument byte. When the function 
byte is nonzero, the operation is completed by insert- 
ing the related argument address in general register 
1, and by inserting the function byte in general regis- 
ter 2. 

The bytes of the first operand are selected one by 
one for translation, proceeding from left to right. The 
first operand remains unchanged in storage. Fetching 
of the function byte from the list is performed as in 
iU\NSLATE. The function byte retrieved from the list 
is inspected for the all-zero combination. 

When the function byte is zero, the operation pro- 
ceeds with the next operand byte. When the first op- 
erand field is exhausted before a nonzero function byte 
is encountered, the operation is completed by setting 
the condition code to 0. The contents of general regis- 
ters 1 and 2 remain unchanged. 
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When the function byte is nonzero, the related ar- 
gument address is inserted in the low-order 24 bits of 
general register 1. This address points to the argument 
last translated. The high-order eight bits of register 1 
remain unchanged. The function byte is inserted in 
the low-order eight bits of general register 2. Bits 0-23 
of register 2 remain unchanged. The condition code 
is set to 1 when the one or more argument bytes have 
not been translated. The condition code is set to 2 if 
the last function byte is nonzero. 

Resulting Condition Code: 

All function bytes are zero 

1 Nonzero function byte before the first operand 
field is exhausted 

2 Last function byte is nonzero 

3 ~ 

Program Interruptions: 

Protection ( fetch violation ) 
Addressing 

Programming Note 

The TRANSLATE AND TEST is uscful for Scanning an in- 
put stream and locating delimiters. The stream can 
thus be rapidly broken into statements or data fields 
for further processing. 



• Edit 

ED Old, Bi), 02(82) 



[SS] 



DE 



][ 



31 32 35 36 



The format of the source (the second operand) is 
changed from packed to zoned and is modified under 
control of the pattern (the first operand). The edited 
result replaces the pattern. 

Editing includes sign and punctuation control and 
the suppressing and protecting of leading zeros. It 
also facilitates programmed blanking for all-zero fields. 
Several fields may be edited in one operation, and 
numeric information may be combined with text. 

The length field applies to the pattern (the first 
operand). The pattern has the zoned format and 
may contain any character. The source (the second 
operand ) has the packed format and must contain valid 
decimal-digit and sign codes. The leftmost four bits 
of a source byte must contain only the codes 0000- 
1001; the codes 1010-1111 are recognized as a data 
exception and cause a program interruption. The 
rightmost four bits are recognized as either a sign or 
a decimal digit. 

Both operands are processed left to right one byte 
at a time. Overlapping pattern and source fields give 
unpredictable results. 
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NAME 

Digit selector 
Significance starter 
Field separator 
Message character 
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During the editing process, each character of the 
pattern is aifected in one of three ways: 

1. It is left unchanged. 

2. It is replaced by a source digit expanded to 
zoned format. 

3. It is replaced by the first character in the pattern, 
called the fill character. 

Which of the three actions takes place is determined 
by one or more of the following: the type of the pat- 
tern character, the state of the significance indicator, 
and whether the source digit examined is zero. 

Pattern Characters: There are four types of pattern 
characters: digit selector, significance starter, field 
separator, and message character. Their coding is as 
follows: 

CODE 

0010 0000 

0010 0001 

0010 0010 

Any other 

The detection of either a digit selector or a signifi- 
cance starter in the pattern causes an examination to 
be made of the significance indicator and of a source 
digit. As a result, either the expanded source digit 
or the fill character, as appropriate, is selected to re- 
place the pattern character. Additionally, encounter- 
ing a digit selector or a significance starter may cause 
the significance indicator to be changed. 

The field separator identifies individual fields in a 
multiple-field editing operation. It is always replaced 
in the result by the fill character, and the significance 
indicator is always off after the field separator is en- 
countered. 

Message characters in the pattern are either re- 
placed by the fill character or remain unchanged in 
the result, depending on the state of the significance 
indicator. They may thus be used for padding, punc- 
tuation, or text in the significant portion of a field or 
for the insertion of sign-dependent symbols. 

Fill Character: The fill character is obtained from 
the pattern as part of the editing operation: The first 
character of the pattern is used as the fill character. 
The choice of the fill character is not dependent on 
the code of the first pattern character and on the edit- 
ing function, if any, initiated upon recognition of the 
code. If this character is a digit selector or significance 
starter, the indicated editing action is taken after the 
code has been assigned to the fill character. 

Source Digits: Each time a digit selector or signifi- 
cance starter is encountered in the pattern, a new 
source digit is examined for placement in the pattern 
field. The source digit either is zoned and replaces 
the pattern character or is disregarded. When a sign 
code is detected in the four high-order bit positions, 
the operation is terminated. 



The source digits are selected one byte at a time, 
and a source byte is fetched for inspection only once 
during an editing operation. Each source digit is ex- 
amined only once for a zero value. The leftmost four 
bits of each byte are examined first, and the rightmost 
four bits, when they represent a decimal-digit code, 
remain available for the next pattern character that 
calls for a digit examination. At the time the high- 
order digit of a source byte is examined, the low-order 
four bits are checked for the existence of a sign code. 
When a sign code is encountered in the four rightmost 
bit positions, these bits are not treated as a decimal- 
digit code, and a new source byte is fetched from 
storage for the next pattern character that calls for a 
source-digit examination. 

When the source digit is stored in the result, its 
code is expanded from the packed to the zoned for- 
mat by attching a zone. When psw bit 12 is zero, the 
preferred ebcdic zone code 1111 is generated. When 
PSW bit 12 is one, the preferred usascii-8 zone code 
0101 is generated. 

Significance Indicator: The significance indicator, by 
its on or off state, indicates the significance or non- 
significance, respectively, of subsequent source digits 
or message characters. Significant source digits replace 
their corresponding digit selectors or significance 
starters in the result. Significant message characters 
remain unchanged in the result. 

The significance indicator, by its on or off state, in- 
dicates also the negative or positive value, respec- 
tively, of the source and is used as one factor in the 
setting of the condition code. 

The indicator is set to the oflF state, if not already 
so set, at the start of the editing operation, after a 
field separator is encountered, or after a source byte 
is examined that has a plus code in the four low-order 
bit positions. Any of the codes 1010, 1100, 1110, and 
1111 is considered a plus code. 

The indicator is set to the on state, if not already 
so set, when a significance starter is encountered 
whose source digit is a valid decimal digit, or when a 
digit selector is encountered whose source digit is a 
nonzero decimal digit, and if in both instances the 
source byte does not have a plus code in the four low- 
order bit positions. 

In all other situations, the indicator is not changed. 
A minus sign code has no effect on the significance 
indicator. 

Result Characters: The field resulting from an edit- 
ing operation replaces and is equal in length to the 
pattern. It is composed from pattern characters, fill 
characters, and zoned source digits. 

If the pattern character is a message character and 
the significance indicator is on, the message character 
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remains unchanged in the result. If the pattern 
character is a field separator or if the significance in- 
dicator is off when a message character is encountered 
in the pattern, the fill character replaces the pattern 
character in the result. 

If a digit selector or significance starter is encoun- 
tered in the pattern with the significance indicator off 
and the source digit zero, the source digit is con- 
sidered nonsignificant, and the fill character replaces 
the pattern character. If a digit selector or significance 
starter is encountered with either the significance in- 
dicator on or with a nonzero decimal source digit, the 
source digit is considered significant, is zoned, and re- 
places the pattern character in the result. 

Result Condition: All digits examined are tested for 
the code 0000. The sign of the last field edited and 
whether all source digits in the field contain zeros are 
recorded in the condition code at the completion of 
the editing operation. 

The condition code is made when all source digits 
examined in the last field are zeros. When the pattern 
has no digit selectors or significance starters, the 
source is not examined, and the condition code is 
made 0. Similarly, the condition code is made when 
the last character in the pattern is a field separator 
or when no digit selector or significance starter is en- 
countered beyond the last field separator. 

When the last field edited is nonzero and the signif- 
icance indicator is on, the condition code is made 1 to 
indicate a result field less than zero. 

When the last field edited is nonzero and the signif- 
icance indicator is off, the condition code is made 2 
to indicate a result field greater than zero. 
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For multiple-field editing operations the condition 
code reflects the sign and value only of the field fol- 
lowing the last field separator. 

Summary: The following table summarizes the func- 
tions of the editing operation. The leftmost four col- 
umns list all the significant combinations of the four 
conditions that can be encountered in the execution of 
an editing operation. The rightmost two columns list 
the action taken for each case — the type of character 
placed in the result field and the new setting of the 
significance indicator. See Appendix A for an instruc- 
tion-use example of edit. 

Resulting Condition Code: 

Source inspected for last field is zero 

1 Source inspected for last field is less than zero 

2 Source inspected for last field is greater than 
zero 

3 - 

Program Interruptions: 

Operation ( if decimal feature is not installed ) 
Protection ( store or fetch violation ) 
Addressing 
Data 

Programming Notes 

As a rule the source is shorter than the pattern be- 
cause for each source digit a zone and numeric are 
inserted in the result. 

The total number of digit selectors and significance 
starters in the pattern must equal the number of 
source digits to be edited. 

If the fill character is a blank, if no significance 
started appears in the pattern, and if the source is all 
zeros, the editing operation blanks the result field. 







CONDITIONS 






RESULTS 


STATE OF 
SIGNIFICANCE 




PREVIOUS STATE 




LOW-ORDER 




INDICATOR AT 


PATTERN 


OF SIGNIFICANCE 


SOXmCE 


SOURCE DIGIT 


RESULT 


END OF DIGIT 


CHARACTER 


INDICATOR 


DIGIT 


IS A PLUS SIGN 


CHARACTER 


EXAMINATION 


Digit selector 


off 







# 


fill character 


off 








1-9 


no 


source digit 


on 








1-9 


yes 


source digit 


off 




on 




0-9 


no 


source digit 


on 








0-9 


yes 


source digit 


off 


Significance starter 


off 







no 


fill character 


on 











yes 


fill character 


off 








1-9 


no 


source digit 


on 








1-9 


yes 


source digit 


off 




on 




0-9 


no 


source digit 


on 








0-9 


yes 


source digit 


off 


Field separator 


« 




## 


## 


fill character 


off 


Message character 


off 




*« 


«« 


fill character 


off 




on 




»« 


«« 


message character 


on 



"No eflfect on result character and new state of significance indicator. 
""Not applicable because source digit not examined. 
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> Edit and Mark 
EDMK Di(L, BiK 02(82) 
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The fonnat of the source (the second operand) is 
changed from packed to zoned and is modified under 
control of the pattern ( the first operand ) . The address 
of each first significant result character is recorded in 
general register 1. The edited result replaces the pat- 
tern. 

The instruction edft and mark is identical to edit 
except for the additional function of inserting the ad- 
dress of the result character in bit positions 8-31 of 
general register 1 whenever the result character is a 
zoned source digit and the significance indicator was 
off before the examination. The use of general register 
1 is implied. The contents of bit positions 0-7 of the 
register are not changed. 

Refer to Appendix A for an instruction-use example. 

Resulting Condition Code: 

Source inspected for last field is zero 

1 Source inspected for last field is less than zero 

2 Source inspected for last field is greater than 
zero 

3 - 

Program Interruptions: 

Operation ( if decimal feature is not installed ) 
Protection ( store or fetch violation ) 
Addressing 
Data 

Programming Notes 

The instruction edit and mark facilitates the program- 
ming of floating currency-symbol insertion. The char- 
acter address inserted in general register 1 is one 
more than the address where a floating currency-sign 
would be inserted. The branch on count, with zero 
in the Rg field, may be used to reduce the inserted 
address by one. 

The character address is not stored when signifi- 
cance is forced. To ensure that general register 1 con- 
tains a valid address when significance is forced, it is 
necessary to place into the register beforehand the 
address of the pattern character that immediately fol- 
lows the significance starter. 

When a single instruction is used to edit several 
fields, the address of the first significant result charac- 
ter of each field is inserted into bit positions 8-31 of 
general register 1. Only the address of the first signi- 
ficant character of the last field is available after the 
instruction is completed. 



Shift Left Single 

5LL Ru 02(82) [RS] 
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The first operand is shifted left the number of bits 
specified by the second operand address. 

The second operand address is not used to address 
data; its low-order six bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

AU 32 bits of the general register specified by Ri 
participate in the shift. High-order bits are shifted out 
without inspection and are lost. Zeros are supplied to 
the vacated low-order register positions. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 

Shift Right Single 

SRL R„ 02(82) [RS] 
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The first operand is shifted right the number of bits 
specified by the second operand address. 

The second operand address is not used to address 
data; its low-order six bits indicate the number of bit 
positions to be shifted. The remainder of the address 
is ignored. 

All 32 bits of the general register specified by Ri 
participate in the shift. Low-order bits are shifted out 
without inspection and are lost. Zeros are supplied to 
the vacated high-order register positions. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 

Shift Left Double 

SlOl Ru 02(82) [RS] 



8D 



The double-length first operand is shifted left the 
number of bits specified by the second operand ad- 
dress. 

The Ri field of the instruction specifies an even/odd 
pair of registers and must contain an even register 
address. An odd value for Ri is a specification excep- 
tion and causes a program interruption. The second 
operand address is not used to address data; its low- 
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order six bits indicate the number of bit positions to 
be shifted. The remainder of the address is ignored. 

All 64 bits of the even/odd register pair specified 
by Ri participate in the shift. High-order bits are 
shifted out of the even-numbered register without in- 
spection and are lost. Zeros are supplied to the vacated 
positions of the registers. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Specification 

Shift Right Double 

5RDL Rj, 02(82) [RS] 



8C 


^1 


m 


h 


^2 



The double-length first operand is shifted right the 
number of bits specified by the second operand ad- 
dress. 

The Ri field of the instruction specifies an even/odd 
pair of registers and must contain an even register ad- 
dress. An odd value for Ri is a specification exception 
and causes a program interruption. The second oper- 
and address is not used to address data; its low-order 
six bits indicate the number of bit positions to be 
shifted. The remainder of the address is ignored. 

All 64 bits of the even/odd register pair specified 
by Ri participate in the shift. Low-order bits are 
shifted out of the odd-numbered register without in- 
spection and are lost. Zeros are supplied to the vacated 
positions of the registers. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Specification 

Programming Note 

The logical shifts differ from the arithmetic shifts in 
that the high-order bit participates in the shift and is 
not propagated, the condition code is not changed, 
and no overflow occurs. 



Logical Operation Exceptions 

Exceptional operation codes, operand designations, 
data, or results cause a program interruption. When 
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the interruption occurs, the current psw is stored as an 
old psw and a new psw is obtained. The interruption 
code in the old psw identifies the cause of the inter- 
ruption. The following exceptions cause a program 
interruption in logical operations. 

Operation: The decimal feature is not installed, and 
the instruction is edit or edit and mark. The instruc- 
tion is suppressed. Therefore, the condition code and 
data in registers and storage remain unchanged. 

Protection: The key of an operand in storage does 
not match the protection key in the psw. The opera- 
tion is suppressed on a store violation. Therefore, the 
condition code and data in registers and storage re- 
main unchanged. The only exceptions are the variable- 
length, storage-to-storage operations (those contain- 
ing a length specification ) , which are terminated. The 
operation is terminated on any fetch violation. For 
terminated operations, the result data and condition 
code, if affected, are unpredictable and should not be 
used for further computation. 

Addressing: An address designates an operand loca- 
tion outside the available storage for the installation: 
In most cases, the operation is terminated. The result 
data and the condition code, if affected, are unpre- 
dictable and should not be used for further compu- 
tation. The exceptions are the immediate operations 

AND (ni), exclusive OR (xi), OR (oi), MOVE (mVi), 

and store character, which are suppressed. 

Specification: A fullword operand in a storage-to- 
register operation is not located on a 32-bit boundary 
or an odd register address is specified for a pair of 
general registers containing a 64-bit operand. The op- 
eration is suppressed. Therefore, the condition code 
and data in registers and storage remain unchanged. 

Data: A digit code of the second operand in edit or 
edit AND mark is invalid. The operation is terminated. 
The result data and the condition code are unpredict- 
able and should not be used for further computation. 

Operand addresses are tested only when used to ad- 
dress storage. Addresses used as a shift amount are 
not tested. Similarly, the address generated by the use 
of load address is not tested. The address restrictions 
do not apply to the components from which an ad- 
dress is generated — the contents of the Di and D2 
fields, and the contents of the registers specified by 
X2, Bi, and B2. 
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Branching 



Instructions are performed by the central process- 
ing unit primarily in the sequential order of their 
locations. A departure from this normal sequential 
operation may occur when branching is performed. 
The branching instructions provide a means for mak- 
ing a two-way choice, to reference a subroutine, or to 
repeat a segment of coding, such as a loop. 

Branching is performed by introducing a branch ad- 
dress as a new instruction address. 

The branch address may be obtained from one of 
the general registers or it may be the address specified 
by the instruction. The branch address is independent 
of the updated instruction address. 

The detailed operation of branching is determined 
by the condition code which is part of the program 
status word (psw) or by the results in the general reg- 
isters which are specified in the loop-closing opera- 
tions. 

During a branching operation, the rightmost half of 
the PSW, including the updated instruction address, 
may be stored before the instruction address is re- 
placed by the branch address. The stored information 
may be used to link the new instruction sequence with 
the preceding sequence. 

The instruction execute is grouped with the branch- 
ing instructions. The branch address of execute desig- 
nates a single instruction to be inserted in the instruc- 
tion sequence. The updated instruction address norm- 
ally is not changed in this operation, and only the in- 
struction located at the branch address is executed. 

All branching operations are provided in the stand- 
ard instruction set. 

Normal Sequential Operation 

Normally, operation of the cpu is controlled by in- 
structions taken in sequence. An instruction is fetched 
from a location specified by the instruction-address 
field of the psw. The instruction address is increased 
by the number of bytes of the instruction to address 
the next instruction in sequence. This new instruction- 
address value, called the updated instruction address, 
replaces the previous contents of the instruction-ad- 
dress field in the psw. The current instruction is exe- 
cuted, and the same steps are repeated, using the up- 
dated instruction address to fetch the next instruction. 
Instructions occupy a halfword or a multiple there- 
of. An instruction may have up to three half words. 
The number of halfwords in an instruction is specified 
by the first two instruction bits. A 00 code indicates a 



halfword instruction, codes 01 and 10 indicate a two- 
halfword instruction, and code 11 indicates a three- 
half word instruction, 

Halfword Format 



Op Code 



Two-Halfword Format 












Op Code 


^^<;^<x^^<^<?^::<^ 


B/B2 


D1/D2 


7 8 

Three-Halfword Format 


1516 1920 




31 


Op Code 


<<:<^<^<^<:<^ 


Bl 


Dl 



B2 



D2 



Storage wraps around from the maximum address- 
able storage location, byte location 16,777,215, to byte 
location 0. An instruction having its last halfword at 
the maximum storage location is followed by the in- 
struction at address 0. Also, a multiple-half word in- 
struction may straddle the upper storage boundary; no 
special indication is given in these cases. 

Conceptually, an instruction is fetched from storage 
after the preceding operation is completed and before 
execution of the current operation, even though physi- 
cal storage width and overlap of instruction execu- 
tion with storage access may cause actual instruction 
fetching to be different. 

A change in the sequential operation may be caused 
by branching, status switching, interruption, or man- 
ual intervention. Sequential operation is initiated and 
terminated from the system control panel. 

Programming Note 

It is possible to modify an instruction in storage by 

means of the immediately preceding instruction. 

Sequential Operation Exceptions 

Exceptional instruction addresses or operation codes 
cause a program interruption. When the interruption 
occurs, the current psw is stored as an old psw, and a 
new psw is obtained. The interruption code in the old 
psw identifies the cause of the interruption. (In this 
manual, part of the description of each class of instruc- 
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tions is a list of the program interruptions that may 
occur for these instructions.) The new psw is not 
checked for exceptions when it becomes current. These 
checks occur when the next instruction is executed. 
The following program interruptions may occur in 
normal instruction sequencing, independently of the 
instruction performed. 

Operation: An operation exception occurs when the 
CPU attempts to decode an operation code that is not 
assigned. The operation exception can be accompanied 
by an addressing or specification exception if the in- 
struction class associated with the undefined operation 
has uniform requirements for operand designation. An 
instruction class is a group of instructions whose four 
leftmost bits are identical. 

Protection: A protection exception occurs when an 
attempt is made to fetch an instruction halfword from 
a fetch-protected location. This error can occur when 
normal instruction sequencing goes from an unpro- 
tected region into a protected region, or following 
a branching or load-psw operation or an interruption. 

Addressing: An addressing exception occurs when 
an instruction halfword is located outside the avail- 
able storage for the particular installation. This situa- 
tion can occur when normal instruction sequencing 
goes from a valid storage region into an unavailable 
region, or following a branching or load-PSW opera- 
tion or an interruption. However, when the last loca- 
tions in available storage contain an instruction that 
again introduces a valid instruction address (i.e., a 
branch), no program interruption is caused even 
though the updated instruction address designates an 
unavailable location. 

Specification: A specification exception occurs when 
the instruction address in the psw is odd. This odd- 
address error can occur only after a branching or load- 
psw operation or after an interruption. 

A specification exception will occur when the pro- 
tection key is nonzero and the protection feature is not 
installed. This error can occur after a psw is loaded 
or after an interruption. 

In each case, the instruction is suppressed; therefore, 
the condition code and data in storage and registers 
remain unchanged. The instruction address stored as 
part of the old psw has been updated by the number 
of halfwords indicated by the instruction length code 
in the old psw. 

Programming Notes 

When a program interruption occurs, the current psw 
is stored in the old psw location. The instruction ad- 
dress stored as part of this old psw is thus the updated 
instruction address, having been updated by the num- 
ber of halfwords indicated in the instruction-length 



code of the same psw. The interruption code in this old 
PSW identifies the cause of the interruption and aids 
in the programmed interpretation of the old psw. 

If the new psw for a program interruption has an 
unacceptable instruction address, another program in- 
terruption occurs. Since this second program interrup- 
tion introduces the same unacceptable instruction ad- 
dress, a string of program interruptions is established 
which may be broken only by an external or i/o inter- 
ruption. If these interruptions also have an unaccept- 
able new PSW, new supervisor information must be 
introduced by initial program loading or by manual 
intervention. 



Decisiori'Making 

Branching may be conditional or unconditional. Un- 
conditional branches replace the updated instruction 
address with the branch address. Conditional branches 
may use the branch address or may leave the updated 
instruction address unchanged. When branching takes 
place, the instruction is called successful; otherwise, it 
is called unsuccessful. 

Whether a conditional branch is successful depends 
on the result of operations concurrent with the branch 
or preceding the branch. The former case is repre- 
sented by BRANCH ON COUNT and the branch-on-index 
instructions. The latter case is represented by branch 
ON CONDITION, which inspects the condition code that 
reflects the result of a previous arithmetic, logical, or 
i/o operation. 

The condition code provides a means for data-de- 
pendent decision-making. The code is inspected to 
qualify the execution of the conditional-branch instruc- 
tions. The code is set by some operations to reflect the 
result of the operation, independently of the previous 
setting of the code. The code remains unchanged for 
all other operations. 

The condition code occupies bit positions 34 and 35 
of the PSW. When the psw is stored during status 
switching, the condition code is preserved as part of 
the PSW. Similarly, the condition code is stored as part 
of the rightmost half of the PSW in a branch-and-link 
operation. A new condition code is obtained by a load 
PSW or SET program mask or by the new psw loaded 
as a result of an interruption. 

The condition code indicates the outcome of some 
of the arithmetic, logical, or i/o operations. It is not 
changed for any branching operation, except for exe- 
cute. In the case of execute, the condition code is set 
or left unchanged by the subject instruction, as would 
have been the case had the subject instruction been in 
the normal instruction stream. 
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The table at the end of this section lists all instruc- 
tions capable of altering the condition code and the 
meaning of the codes for these instructions. 

Instruction Formats 

Branching instructions use the following three formats: 

RR Format 



Op Code 


Ri/Mi Rj 



RX Format 



Op Code 


R|/M, 


^2 


^2 


°2 


7 a 1112 15 16 1920 

RS Format 




31 


Op Code 


h 


h 


^2 


°2 



11 12 15 16 



In these formats Ri specifies the address of a gen- 
eral register. In branch on condition a mask field 
(Ml) identifies the bit values of the condition code. 
The branch address is defined differently for the three 
formats. 

In the RR format, the R2 field specifies the address of 
a general register containing the branch address, ex- 
cept when R2 is zero, which indicates no branching. 
The same register may be specified by Ri and R2. 

In the RX format, the contents of the general reg- 
isters specified by the X2 and B2 fields are added to 
the content of the D2 field to form the branch address. 

In the RS format, the content of the general register 
specified by the B2 field is added to the content of the 
D2 field to form the branch address. The R.i field in 
this format specifies the location of the second operand 
and implies the location of the third operand. The first 
operand is specified by the Ri field. The third operand 
location is always odd. If the R3 field specifies an even 
register, the third operand is obtained from the next 
higher addressed register. If the R3 field specifies an 
odd register, the third operand location coincides with 
the second operand location. 

A zero in a B2 or X2 field indicates the absence of 
the corresponding address component. 

An instruction can specify the same general register 
for both address modification and operand location. 
The order in which the contents of the general reg- 
isters are used for the different parts of an operation 



3. Replacement of the instruction address by the 
branch address obtained under step 1. 

Results are placed in the general register specified 
by Ri. Except for the storing of the final results, the 
contents of all general registers and storage locations 
participating in the addressing or execution part of an 
operation remain unchanged. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction. For branch on index 
high, for example, bxh is the mnemonic and Ri, R3, 
D2(B2) the operand designation. 



Programming Note 

In several instructions the branch address may be 
specified in two ways: in the RX format, the branch 
address is the address specified by X2, B2, and D2; in 
the RR format, the branch address is in the low-order 
24 bits of the register specified by R2. Note that the 
relation of the two formats in branch-address specifica- 
tion is not the same as in operand-address specifica- 
tion. For operands, the address specified by X2, B2, 
and D2 is the operand address, but the register speci- 
fied by R2 contains the operand itself. 



Branching Instructions 

The branching instructions and their mnemonics, for- 
mats, and operation codes follow. The table also shows 
the exceptions that cause a program interruption dur- 
ing execution of execute. The subject instruction of 
EXECUTE follows its own rules for interruptions. The 
condition code is never changed for branching in- 
structions. 



is: 



1. Address computation. 

2. Arithmetic or link information storage. 



NAME 


MNEMONIC 


TYPE 


EXCEPTIONS 


CODE 


Branch on 










Condition 


BCR 


RR 




07 


Branch on 










Condition 


BC 


RX 




47 


Branch and Link 


BALR 


RR 




05 


Branch and Link 


BAL 


RX 




45 


Branch on Count 


BCTR 


RR 




06 


Branch on Count 


BCT 


RX 




46 


Branch on Index 










High 


BXH 


RS 




86 


Branch on Index 










Low or Equal 


BXLE 


RS 




87 


Execute 


EX 


RX 


P,A,S, EX 


44 


NOTES 










A Addressing exception 








EX Execute exception 








S Specification exception 








P Protection exception 
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Branch On Condition 
BCR Ml, R2 [RR] 



07 


M, 


R2 



BC MuD2(X2,B2) 



[RX] 



47 


M, 


^2 


'2 


°2 



The updated instruction address is replaced by the 
branch address if the state of the condition code is as 
specified by Mi; otherwise, normal instruction se- 
quencing proceeds with the updated instruction ad- 
dress. 

The Ml field is used as a four-bit mask. The four bits 
of the mask correspond, left to right, with the four 
condition codes (0, 1, 2, and 3) as follows: 



INSTRUCTION 


MASK POSITION 


CONDITION 


BIT 


VALUE 


CODE 


8 


8 





9 


4 


1 


10 


2 


2 


11 


1 


3 



The branch is successful whenever the condition 
code has a corresponding mask bit of one. 

Condition Code: The code remains unchanged. 
Program Interruptions: None. 

Programming Note 

When a branch is to be made on more than one condi- 
tion code, the pertinent condition codes are specified 
in the mask as the sum of their mask position values. 
A mask of 12, for example, specifies that a branch is to 
be made on condition codes and 1. 

When all four mask bits are ones, that is, the mask 
position value is 15, the branch is unconditional. When 
all four mask bits are zero or when the R2 field in the 
RR format contains zero, the branch instruction is 
equivalent to a no-operation. 



Condition-Code Settings 



Fixed-Point Arithmetic 

Add H/F zero 

Add Logical zero, 

no carry 

Compare H/F equal 

Load and Test zero 

Load Complement zero 

Load Negative zero 

Load Positive zero 

Shift Left Double zero 

Shift Left Single zero 

Shift Right Double zero 

Shift Right Single zero 

Subtract H/F zero 
Subtract Logical 



CODE STATE 

1 2 



< zero 
not zero, 
no carry 

low 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 
not zero, 
no carry 



> zero 
zero, 
carry 
high 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 
zero, 
carry 



overflow 

not zero, 

carry 

carry 
overflow 

overflow 
overflow 
overflow 



overflow 

not zero, 

carry 





Decimal Arithmetic 

Add Decimal zero 

Compare Decimal equal 

Subtract Decimal zero 

Zero and Add zero"^ 

Floating-Point Arithmetic 
Add Normalized 

S/L zero 
Add Unnormalized 

S/L zero 

Compare S/L equal 

Load and Test S/L zero 
Load Complement 

S/L zero 
Load Negative S/L zero 
Load Positive S/L zero 
Subtract Normal- 
ized S/L zero 
Subtract Unnorm- 
alized S/L zero 

Logical Operations 

And zero 

Compare Logical equal 

Edit zero 

Edit and Mark zero 

Exclusive Or zero 

Or zero 

Test Under Mask zero 

Translate and Test zero 

Status Switching 

Test and Set zero 

Input/Output Operations 



CODE STATE 

12 3 

< zero > zero overflow 
low high 

< zero > zero overflow 

< zero > zero overflow 



< zero > zero 



< zero 
low 

< zero 

< zero 

< zero 



< zero 

< zero 



> zero 
high 

> zero 

> zero 

> zero 

> zero 

> zero 



overflow 
overflow 



overflow 
overflow 



not zero 
low high 

< zero > zero 

< zero > zero 
not zero 

not zero 
mixed 
incomplete complete 



Halt I/O 
Start I/O 
Test Channel 
Test I/O 



interruption 
pending 

successful 
available 



available 



CSW 
stored 
CSW 
stored 



burst op not oper- 
stopped ational 



busy 



interruption burst 
pending mode 



CSW 
stored 



busy 



not oper- 
ational 
not oper- 
ational 
not oper- 
ational 



avaflable Unit and channel available 

burst op stopped Burst operation stopped 

busy Unit or channel busy 

carry A carryout of the sign position occurs 

complete Last result byte nonzero 

CSW stored Chanel status word stored 

equal Operands compare equal 

F FuUword 

> zero Result is greater than zero 

H Halfword 

halted Data transmission stopped. Unit in halt-reset 

mode 

high First operand compares high 

incomplete Nonzero result byte; not last 

L Long precision 

< zero Result is less than zero 

low First operand compares low 

mixed Selected bits are both zero and one 

not operational Unit or channel not operational 

not zero Result is not all zero 

one Selected bits are one 

overflow Result overflows 

S Short precision 

zero Result or selected bits are zero 
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Note: The condition code also may be changed by 
LOAD psw, SET PROGRAM MASK, and DIAGNOSE and by an 
interruption. 



Branch and Link 
BALR Ri, R2 [RR] 



05 


^1 


R2 



7 8 11 12 15 



BAL R„ DpJXs, Bg) 



[RX] 



45 



7 8 11 12 15 16 19 20 



The rightmost 32 bits of the psw, including the up- 
dated instruction address, are stored as link informa- 
tion in the general register specified by Ri. Subse- 
quently, the instruction address is replaced by the 
branch address. 

The branch address is determined before the link 
information is stored. The link information contains 
the instruction length code, the condition code, and 
the program mask bits, as well as the updated instruc- 
tion address. The instruction-length code is 1 or 2, 
depending on the format of the branch and link. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 

Programming Note 

The link information is stored without branching when 
in the rr format the R2 field contains zero. 

When BRANCH and link is the subject instruction of 
EXECUTE, the instruction-length code is 2. 

Branch On Count 
BCTR R„ Ro [RR] 



06 


^ 


«2 



BCT R„ 02^X3, B2) 



[RX] 



4i 


^ 


'<2 


^2 


°2 



The content of the general register specified by Ri is 
algebraically reduced by one. When the result is zero, 
normal instruction sequencing proceeds with the up 
dated instruction address. When the result is not zero, 
the instruction address is replaced by the branch ad 
dress. 



The branch address is determined prior to the count- 
ing operation. Counting does not change the condition 
code. The overflow occurring on transition frora the 
maximum negative number to the maximum positive 
number is ignored. Otherwise, the subtraction pro- 
ceeds as in fixed-point arithmetic, and all 32 bits of the 
general register participate in the operation. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 

Programming Notes 

An initial count of one results in zero, and no branch- 
ing takes place. An initial count of zero results in 
minus one and causes branching to be executed. 

Counting is performed without branching when the 
R2 field in the rr format contains zero. 

Branch On Index High 

BXH Rj, R„ D2(B2) [RS] 



86 



R. 



An increment is added to the first operand, and the 
sum is compared algebraically with a comparand. Sub- 
sequently, the sum is placed in the first operand loca- 
tion, regardless of whether the branch is taken. When 
the sum is high, the instruction address is replaced by 
the branch address. When the sum is low or equal, in- 
struction sequencing proceeds with the updated in- 
struction address. 

The first operand and the increment are in the 
registers specified by Ri and R3. The comparand 
register address is odd and is either one larger than R3 
or equal to R^. The branch address is determined prior 
to the addition and comparison. 

Overflow caused by the addition is ignored and does 
not affect the comparison. Otherwise, the addition and 
comparison proceed as in fixed-point arithmetic;. All 
32 bits of the general registers participate in the opera- 
tions, and negative quantities are expressed in two's- 
complement notation. When the first operand and 
comparand locations coincide, the original register 
contents are used as the comparand. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 

Programming Note 

The name "branch on index high" indicates that one 
of the major purposes of this instruction is the incre- 
menting and testing of an index value. The increment 
may be algebraic and of any magnitude. 



Branch On Index Low or Equal 
BXLE Ri,R3, 02(82) [RS] 



87 


«1 


^3 


^2 


■^2 



An increment is added to the first operand, and the 
sum is compared algebraically with a comparand. 
Subsequently, the sum is placed in the first operand 
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location, regardless of whether the branch is taken. 
When the sum is low or equal, the instruction address 
is replaced by the branch address. When the sum is 
high, normal instruction sequencing proceeds with the 
updated instruction address. 

The first operand and the increment are in the reg- 
isters specified by Ri and R3. The comparand register 
address is odd and is either one larger than R3 or equal 
to R3. The branch address is determined prior to the 
addition and comparison. 

This instruction is similar to branch on index high, 
except that the branch is successful when the sum is 
low or equal compared to the comparand. 

Condition Code: The code remains unchanged. 

Program Interruptions: None. 



Execute 

EX RuD2(X^,B2) 



[RX] 



u 


^1 


'<2 


^2 


"2 



The single instruction at the branch address is modi- 
fied by the content of the general register specified by 
Ri, and the resulting subject instruction is executed. 

Bits 8-15 of the instruction designated by the branch 
address are OR'ed with bits 24-31 of the register speci- 
fied by Ri, except when register is specified, which 
indicates that no modification takes place. The sub- 
ject instruction may be 16, 32, or 48 bits in length. 
The OR'ing does not change either the content of the 
register specified by Ri or the instruction in storage 
and is effective only for the interpretation of the in- 
struction to be executed. 

The execution and exception handling of the sub- 
ject instruction are exactly as if the subject instruction 
were obtained in normal sequential operation, except 
for instruction address and instruction-length record- 
ing. 

The instruction address ot tne psw is increased by 
the length of execute. This updated address and the 
length code (2) of execute are stored in the psw in 
the event of a branch-and-link subject instruction or 
in the event of an interruption. 

When the subject instruction is a successful branch- 
ing instruction, the updated instruction address of the 
psw is replaced by the branch address of the subject 
instruction. When the subject instruction in turn is an 
execute, an execute exception occurs and results in a 
program interruption. The effective address of exe- 
cute must be even; if not, a specification exception will 
cause a program interruption. 

Condition Code: The code may be set by the sub- 
ject instruction. 



Program Interruptions: 
Execute 

Protection ( fetch violation ) 
Addressing 
Specification 

Programming Notes 

The OR'ing of eight bits from the general register with 
the designated instruction permits indirect length, in- 
dex, mask, immediate data, and arithmetic-register 
specification. 

If the subject instruction is a successful branch, the 
length code still stands at 2. 

An addressing or specification exception may be 
caused by execute or by the subject instruction. 



Execute Exceptions 

Exceptional operand designations and a subject-in- 
struction operation code specifying execute cause a 
program interruption. When the interruption occurs, 
the current psw is stored as an old psw, and a new 
PSW is obtained. The interruption code in the old psw 
identifies the cause. Exceptions that cause a program 
interruption in the use of execute are: 

Execute: An execute instruction has as its subject 
instruction another execute. 

Protection: An execute specifies a subject instruc- 
tion halfword in a fetch-protected area. 

Addressing: The branch address of execute desig- 
nates an instruction-halfword location outside the 
available storage for the particular installation. 

Specification: The branch address of execute is odd. 

These four exceptions occur only for execute. The 
instruction is suppressed. Therefore, the condition 
code and data in registers and storage remain un- 
changed. 

Exceptions arising for the subject instruction of exe- 
cute are the same as would have arisen had the sub- 
ject instruction been in the normal instruction stream. 
However, the instruction address stored in the old 
PSW is the address of the instruction following execute. 
Similarly, the instruction-length code in the old psw 
is the instruction-length code (2) of execute. 

The address restrictions do not apply to the com- 
ponents from which an address is generated — the 
content of the Di field and the content of the register 
specified by Bi. 

Programming Note 

An unavailable or odd branch address of a successful 
branch is detected during the execution of the next 
instruction and not as part of the branch. 
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Status Switching 



A set of operations is provided to switch the status of 
the CPU, of storage, and of communication between 
systems. 

The over-all cpu status is determined by several 
program-state alternatives, each of which can be 
changed independently to its opposite and most of 
which are indicated by a bit in the program status 
word (psw). The cpu status is further defined by the 
instruction address, the condition code, the instruction- 
length code, the storage-protection key, and the inter- 
ruption code. These all occupy fields in the psw. 

Protection of main storage is achieved by matching 
a key in storage with a protection key in the psw or 
in a channel. The protection status of storage may be 
changed by introducing new storage keys, using set 
STORAGE KEY. The storagc keys may be inspected by 

using INSERT STORAGE KEY. 

Facilities are provided whereby a system formed by 
CPU, storage, and i/o can communicate with other 
systems. The instruction read direct makes signals 
available to the cpu; write direct provides signals to 
other systems. 

All status-switching instructions, other than those of 
the protection feature or direct control feature, are 
provided in the standard instruction set. 

Program States 

The four types of program-state alternatives, which 
determine the over-all cpu status, are named Problem/ 
Supervisor, Wait/Running, Masked/Interruptible, and 
Stopped/Operating. These states differ in the way they 
affect the cpu functions and in the way their status is 
indicated and switched. The masked states have sev- 
eral alternatives; all other states have only one alter- 
native. 

All program states are independent of each other in 
their function, indication, and status switching. Status 
switching does not affect the contents of the arith- 
metic registers or the execution of i/o operations but 
may affect the timer operation. 

Problem State 

The choice between supervisor and problem state de- 
termines whether the full set of instructions is vahd. 
The names of these states reflect their normal use. 

In the problem state all i/o, protection, and direct- 
control instructions are invalid, as well as load psw, 



set system mask, and diagnose. These are called privi- 
leged instructions. A privileged instruction encoun- 
tered in the problem state constitutes a privileged-op- 
eration exception and causes a program interruption. 
In the supervisor state all instructions are valid. 

When bit 15 of the psw is zero, the cpu is in the 
supervisor state. When bit 15 is one, the cpu is in the 
problem state. The supervisor state is not indicated on 
the operator sections of the system control panel. 

The CPU is switched between problem and super- 
visor state by changing bit 15 of the psw. This bit can 
be changed only by introducing a new psw. Thus 
status switching may be performed by load psw, using 
a new psw with the desired value for bit 15. Since 
LOAD PSW is a privileged instruction, the cpu must be 
in the supervisor state prior to the switch. A new psw 
is also introduced when the cpu is interrupted. The 
supervisor call causes an interruption and thus may 
change the cpu state. Similarly, initial program load- 
ing introduces a new Psw and with it a new cpu state. 
The new psw may introduce the problem or supervisor 
state regardless of the preceding state. No explicit op- 
erator control is provided for changing the supervisor 
state. 

Timer updating is not affected by the choice be- 
tween supervisor and problem state. 

Programming Note 

To allow return from an interruption-handling routine 
to a preceding program by a load psw, the psw for 
the interruption routine should specify the supervisor 
state. 

Wait State 

In the wait state no instructions are processed, and 
storage is not addressed repeatedly for this puirpose, 
whereas in the running state, instruction fetching and 
execution proceed in the normal manner. 

When bit 14 of the psw is one, the cpu is waiting. 
When bit 14 is zero, the cpu is in the running state. 
The wait state is indicated on the operator control 
section of the system control panel by the wait light. 

The CPU is switched between wait and running state 
by changing bit 14 of the psw. This bit can be changed 
only by introducing an entire new psw, as is the case 
with the problem-state bit. Thus, switching from the 
running state may be achieved by the privileged in- 
struction LOAD PSW, by an interruption such as for 
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SUPERVISOR CALL, or by initial program loading. Switch- 
ing from the wait state may be achieved by an i/o or 
external interruption or, again, by initial program 
loading. The new psw may introduce the wait or run- 
ning state regardless of the preceding state. No ex- 
plicit operator control is provided for changing the 
wait state. 

Timer updating is not affected by the choice be- 
tween running and wait state. 

Programming Note 

To leave the wait state without manual intervention, 
the CPU should remain interruptible for some active 
i/o or external interruption source. 

Masked States 

The CPU may be masked or interruptible for all i/o, ex- 
ternal, and machine-check interruptions and for some 
program interruptions. When the cpu is interruptible 
for a class of interruptions, these interruptions are 
accepted. When the cpu is masked, the system inter- 
ruptions remain pending, while the program and ma- 
chine-check interruptions are ignored. 

The system mask bits (psw bits 0-7), the program 
mask bits (psw bits 36-39), and the machine-check 
mask bit ( psw bit 13 ) indicate as a group the masked 
state of the cpu. When a mask bit is one, the cpu is 
interruptible for the corresponding interruptions. 
When the mask bit is zero, these interruptions are 
masked off. The system mask bits indicate the masked 
state of the cpu for multiplexor and selector channels 
and the external signals. The program mask bits indi- 
cate the masked state for four of the 15 types of pro- 
gram exceptions. The machine-check mask bit per- 
tains to all machine checks. Program interruptions not 
maskable, as well as the supervisor-call interruption, 
are always taken. The masked states are not indicated 
on the operator sections of the system control panel. 

Most mask bits do not affect the execution of cpu 
operations. The only exception is the significance mask 
bit, which determines the manner in which a floating- 
point operation is completed when a significance ex- 
ception occurs. 

The interruptible state of the cpu is switched by 
changing the mask bits in the psw. The program mask 
may be changed separately by set program mask, and 
the system mask may be changed separately by the 
privileged instruction set system mask. The machine- 
check mask bit can be changed only by introducing an 
entire new psw, as is the case with the problem-state 
and wait-state bits. Thus, a change in the entire 
masked status may be achieved by the privileged in- 
struction LOAD PSW, by an interruption such as for sup- 



ervisor CALL, or by initial program loading. The new 
psw may introduce a new masked state regardless of 
the preceding state. No explicit operator control is 
provided for changing the masked state. 

Timer updating is not affected by the choice be- 
tween masked or interruptible states. 

Programming Note 

To prevent an interruption-handling routine from be- 
ing interrupted before necessary housekeeping steps 
are performed, the new psw for that interruption 
should mask the cpu for further interruptions of the 
kind that caused the interruption. 

Stopped State 

When the cpu is in the stopped state, instructions and 
interruptions are not executed. In the operating state, 
the CPU executes instructions (if not waiting) and in- 
terruptions ( if not masked off ) . 

The stopped state is indicated on the operator con- 
trol section of the system control panel by the manual 
light. The stopped state is not identified by a bit in 
the psw. 

A change in the stopped or operating state can be 
effected only by manual intervention or by machine 
malfunction. No instructions or interruptions can stop 
or start the cpu. The cpu is commanded to stop when 
the stop key on the operator intervention section of 
the system control panel is pressed, when an address 
comparison indicates equality, and when the rate 
switch is set to instruction step. In addition, the cpu 
is placed in the stopped state after power is turned on 
or following a system reset, except during initial pro- 
gram loading. The cpu is placed in the operating state 
when the start key on the operator intervention panel 
is pressed. The cpu is also placed in the operating 
state when initial program loading is commenced. 

The transition from operating to stopped state oc- 
curs at the end of instruction execution and prior to 
starting the next instruction execution. When the cpu 
is in the wait state, the transition takes place immedi- 
ately. All interruptions pending and not masked off 
are taken while the cpu is still in the operating state. 
They cause an old psw to be stored and a new psw to 
be fetched before entering the stopped state. When 
the CPU is in the stopped state, interruptions are not 
taken and remain pending. 

The timer is not updated in the stopped state. 

Programming Notes 

Except for timing considerations and response to 
equipment errors, execution of a program is not af- 
fected by stopping the cpu. 
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When because of machine malfunction the cpu is 
unable to end an instruction, the stop key is not e£Fect- 
ive, and initial program loading or system reset should 
be used. 

Input/output operations continue to completion 
while the cpu is in the problem, wait, masked, or 
stopped state. However, no new i/o operations can be 
initiated while the cpu is stopped, waiting, or in the 
problem state. Also, the interruption caused by i/o 
completion remains pending when masked off or when 
the CPU is in the stopped state. 



Protection 

Protection is provided to protect the contents of cer- 
tain areas of main storage from destruction (or mis- 
use) caused by erroneous storing (or storing and 
fetching) of information during the execution of a 
program. Locations may be protected against store vio- 
lations or against store and fetch violations but never 
against fetch violations alone. This protection is 
achieved by identifying blocks of storage with a key 
and comparing this key with a protection key sup- 
plied with the data to be stored. The detection of a 
mismatch causes the access to be suppressed, and a 
protection exception is recognized. 

Area Identification 

For protection purposes, main storage is divided into 
blocks of 2,048 bytes, each block having an address 
that is a multiple of 2,048. 

Protection Action 

A key is associated with each block of storage. The 
key consists of five bit positions and may be used to 
establish the right of access. When protection only 
against destruction is provided, the low-order bit is 
ignored. When both store and fetch protection is pro- 
vided, the low-order bit of the five-bit key in storage 
designates whether the block is protected against 
fetch-type references. A zero in the low-order bit po- 
sition indicates that only store-type references are 
monitored; a one indicates that protection applies to 
both fetching and storing. The same key setting may 
be used in many blocks. 

When protection applies to a storage reference, the 
key in storage is compared with the protection key. 
Access to storage is permitted only when the key in 
storage matches the protection key in the psw or in 
the channel. The keys are said to match when the four 
high-order bits of the key in storage are equal to the 
protection key or when the protection key is zero. The 
protection key of the current psw is used as the com- 



parand when the operation is specified by an instruc- 
tion. When the reference is specified by a channel 
operation, the protection key supplied to the channel 
by the channel address word is used as the comparand. 

The key in storage is not part of addressable stor- 
age. The key is changed by set storage key and is 
inspected by insert storage key. The protection key 
of the CPU occupies bits 8-11 of the PSW. The protec- 
tion key for i/o operations is specified in bit positions 
0-3 of the channel address word and is recorded in 
bits 0-3 of the channel status word stored as a result 
of the i/o operation. 

The protection system is always active. It is inde- 
pendent of the problem, supervisor, or masked state 
of the CPU and of the type of instruction or i/o com- 
mand being executed. 

When an instruction causes a protection mismatch, 
the protected main-storage location remain,? un- 
changed. 

In general, a store violation by the cpu program 
causes the instruction specifying this location to be 
suppressed when possible, that is, to be omitted en- 
tirely. The operation is terminated only when a pro- 
tection exception is recognized after execution of the 
instruction has progressed to the point that suppres- 
sion is precluded. Fetch violations cause the operation 
to be terminated. 

Protection mismatch due to an i/o operation is in- 
dicated in the channel status word stored as a result 
of the operation. 

Protection is optional on some models. The fetch- 
protection feature requires the presence of the store- 
protection feature. 

Programming Note 

When protection is not installed, the protection key in 
the PSW and the protection key of the channels must 
be zero; otherwise, a program interruption or program- 
check i/o termination occurs. 

When the fetch-protection feature is not installed, 
bit 28 of the register specified by the Ri field of set 
STORAGE KEY is ignored, and during execution of in- 
sert STORAGE key, bit 28 of the register is set to zero. 

Locations Protected 

All main-storage locations where information is stored 
or fetched in the course of an operation are subject 
to protection. A location not actually used does not 
cause protection action. 

Locations whose addresses are generated b)'' the 
CPU for updating or interruption purposes, such as the 
timer, channel status word, or psw addresses, are not 
protected. However, when the program specifies these 
locations, they are subject to protection, 
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Program Status Word 

The psw contains all information not contained in 
storage or registers but required for proper program 
execution. By storing the psw, the program can pre- 
serve the detailed status of the cpu for subsequent in- 
spection. By loading a new psw or part of a psw, the 
state of the cpu may be changed. 

In certain circumstances all of the psw is stored or 
loaded; in others, only part of it. The entire psw is 
stored, and a new psw is introduced when the cpu is 
interrupted. The rightmost 32 bits are stored in 
BRANCH AND LINK. The LOAD PSW iutroduccs a new 
PSW; SET PROGRAM mask introduces a new condition 
code and program-mask field in the psw; set system 
MASK introduces a new system-mask field. 

The PSW has the following format: 

Program Status Word 



System Mask 


Key 


AMWP 


Interruption Code 


78 1112 1516 


31 


ILC 


CC 


Program 


Instruction Address 


32 33 


34 35 


36 39 


40 






63 



The following is a summary of the purposes of the 
PSW fields : 

System Mask: Bits 0-7 of the psw are associated with 
i/o channels and external signals as specified in the 
following table. When a mask bit is one, the source 
can interrupt the cpu. When a mask bit is zero, the 
corresponding source can not interrupt the cpu, and 
interruptions remain pending. 

SYSTEM 
MASK BIT INTERRUPTION SOURCE 

Channel 

1 Channel 1 

2 Channel 2 

3 Channel 3 

4 Channel 4 

5 Channel 5 

6 Channel 6 

7 Timer 

7 Interrupt key 

7 External signal 

Protection Key: Bits 8-11 of the psw form the cpu 
protection key. The key is matched with a storage key 
whenever a result is stored or whenever information 
is fetched from a location that is protected against 
fetching. When protection is not implemented, bits 
8-11 must be zero when loaded; otherwise, a specifica- 
tion exception is recognized when an attempt is made 
to execute the instruction designated by the psw. The 
protection key is stored unchanged. 

ASCn(AJ: When bit 12 of the psw is one, the codes 
preferred for the usascii-8 code are generated for 
decimal results. When psw bit 12 is zero, the codes 
preferred for the extended binary-coded-decimal in- 
terchange code are generated. 
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The following instructions cause either the sign or 
zone code to be generated in accordance with the 
setting of psw bit 12: 



Add Decimal 

Subtract Decimal 

Zero and Add 

Muliply Decimal 

Divide Decimal 

Unpack 

Convert to Decimal 

Edit 

Edit and Mark 



( sign code ) 
(sign code) 
(sign code) 
(sign code) 
(sign code) 
( zone code only ) 
(sign code) 
( zone code ) 
(zone code) 



Machine-Check Mask (M): When bit 13 of the psw 
is one, detection of a machine-check condition causes 
a machine-check interruption, generation of the ma- 
chine-check-out signal and logging of diagnostic in- 
formation. When bit 13 of the psw is zero, the cpu 
is disabled for machine-check interruptions, the asso- 
ciated signal and any diagnostic procedures do not 
take place, and the machine-check condition remains 
pending. 

Wait State (W): When bit 14 of the psw is one, the 
CPU is in the wait state. When psw bit 14 is zero, the 
CPU is in the running state. 

Problem State (P): When bit 15 of the psw is one, 
the CPU is in the problem state. When psw bit 15 is 
zero, the cpu is in the supervisor state. 

Interruption Code: Bits 16-31 of the psw identify 
the cause of an interruption. Use of the code for all 
five interruption types is shown in a table appearing 
in the "Interruptions" section. 

Instruction Length Code (ILC): The code in psw 
bits 32 and 33 indicates the length, in halfwords, of the 
last-interpreted instruction when a program or super- 
visor-call interruption occurs. The code is unpredict- 
able for i/o, external, or machine-check interruptions. 
Encoding of these bits is summarized in a table ap- 
pearing in the "Interruptions" sections. 

Condition Code (CC): Bits 34 and 35 of the psw are 
the two bits of the condition code. The condition 
codes for all instructions are summarized in a table 
appearing in the "Branching" section. 

Program Mask: Bits 36-39 of the psw are the four 
program mask bits. Each bit is associated with a pro- 
gram exception, as specified in the following table. 
When the mask bit is one, the exception results in an 
interruption. When the mask bit is zero, no interrup- 
tion occurs. The significance mask bit also determines 
the manner in which floating-point addition and sub- 
traction are completed. 



PROGRAM 




MASK BIT 


PROGRAM EXCEPTION 


36 
37 

38 
39 


Fixed-point overflow 
Decimal overflow 
Exponent underflow 
Significance 
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Instruction Address: Bits 40-63 of the psw are the in- 
struction address. This address specifies the leftmost 
eight-bit byte position of the next instruction. Bit 63 
must be zero when loaded; otherwise, a specification 
exception is recognized when an attempt is made to 
execute the instruction designated by the PSW. 

Programming Note 

The new psw is not checked for exceptions when the 
new PSW becomes current. These checks are made 
when the next instruction is executed. 



Multisystem Operation 

Various facilities are provided to permit communica- 
tion between individual systems. Messages may be 
transmitted by means of a shared i/o device, a chan- 
nel-to-channel adapter, or a shared storage unit. Sig- 
naling may be accomplished when the direct control 
feature is installed by v^hrite direct and read direct 
and by the sigiial-in lines of the external interruption, 
These facilities are augmented by the ability to re- 
locate direct addressed locations, to signal the ma- 
chine malfunction of one system to another, and to 
initiate system operation from another system. 

Direct Address Relocation 

Addresses 0-4095 can be generated without a base 
address or index. This property is important when the 
PSW and general register contents must be preserved 
and restored during program switching. These ad- 
dresses further include all addresses generated by the 
CPU for fixed locations, such as old psw, new psw, 
channel address word, channel status word, and timer. 

This set of addresses can be relocated by means of a 
main prefix to permit more than one cpu to use one 
uniquely addressed storage. Furthermore, an alternate 
prefix is provided to permit a change in relocation in 
case storage malfunction occurs or reconfiguration be- 
comes otherwise desirable. 

A prefix is used whenever an address has the high- 
order 12 bits all-zero. The use of the prefix is inde- 
pendent of the manner in which the address is gener- 
ated and does not apply to the components, such as the 
base or index registers, from which the address is 
generated. The use of the prefix applies both to ad- 
dresses obtained from the program (cpu or i/o) and 
to fixed addresses generated by the cpu or channel 
for updating or interruption purposes. 

Both the main prefix and alternate prefix occupy 12 
bit positions. One or the other replaces the 12 high- 
order bit positions of the address when these are 
found to contain zero. 



The choice of main or alternate prefix is determined 
by the prefix trigger. This trigger is set during initial 
program loading (ipl) and remains unchanged until 
the next initial program loading occurs. Manual ipl 
sets the prefix trigger to the state of the prefix-select 
switch on the operator control section of the system 
control panel. External start sets the prefix trigger to 
the state indicated by the signal line used. The state 
of the prefix is indicated by the alternate-prefix light 
on the operator intervention section of the system con- 
trol panel. 

The prefixes can be changed by hand within 5 min- 
utes from one prewired encoding to another. The low- 
order four bits of a prefix always have even parity, 
and the total number of one-bits in a prefix cannot 
exceed seven. 

Malfunction Indication 

A machine check out-signal occurs whenever a ma- 
chine check is recognized and the machine-check mask 
bit is one. The signal has 0.5-microsecond to 1.0-micro- 
second duration and is identical in electronic charac- 
teristics to the signals on the signal-out lines of the 
direct control feature. 

The machine check-out signal is given during ma- 
chine-check handling and has a high probability of 
being issued in the presence of machine malfunction. 

System Initialization 

A main external-start line and an alternate external- 
start line respond to 0.5-microsecond to 1.0-micro- 
second pulses. Either line, when pulsed, sets the pre- 
fix trigger to the state indicated by its name and sub- 
sequently starts CPU operation. (Refer to "Initial Pro- 
gram Loading.") 

The definition of the signal to which these lines re- 
spond is identical in electronic characteristic to the 
definition for the signal-in lines of the external inter- 
ruption. 



Instruction format 

Status-switching instructions use the following two 
formats: 

RR Format 



Op Code 


^1 


Rj 



7 8 11 12 15 



SI Format 



Op Code 



1516 1920 
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In the RR format, the Ri field specifies a general reg- 
ister, except for supervisor call. The R2 field speci- 
fies a general register in set storage key and insert 
STORAGE key. The Ri and R2 fields in supervisor call 
contain an identification code. In set program mask 
the R2 field is ignored. 

In the SI format the eight-bit immediate field (I2) 
of the instruction contains an identification code. The 
I2 field is ignored in load psv7, set system mask, and 
test and set. The content of the general register 
specified by Bi is added to the content of the Di field 
to form an address designating the location of an 
operand in storage. Only one operand location is re- 
quired in status-switching operations. 

A zero in the Bi field indicates the absence of the 
corresponding address component. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly lan- 
guage are shown with each instruction. For load 
psw, for example, lpsw is the mnemonic and Di (Bi) 
the operand designation. 



Instructions 

The status-switching instructions and their mnemonics, 
formats, and operation codes follow. The table also 
indicates the feature to which an instruction belongs 
and the exceptions in instruction and operand desig- 
nation that cause a program interruption. 



Load PSW 
Set Program Mask 
Set System Mask 
Supervisor Call 
Set Storage Key 
Insert Storage Key 
Write Direct 
Read Direct 
Diagnose 
Test and Set 



MNEMONIC 
LPSW 

SPM 

SSM 

SVC 

SSK 

ISK 

WRD 

HDD 

TS 



TYPE 



SI 

RR 
SI 
RR 
RR Z 
RR Z 
SI Y 
SI Y 
SI 
SI C 



EXCEPTIONS 
M,P,A,S 

M,P,A 

M, A,S 

M, A,S 

M,P,A 

M,P,A 

M,P,A,S 

P,A 



82 
04 
80 
OA 
08 
09 
84 
85 
83 
93 



NOTES 

A Addressing exception 

C Condition code is set 

L New condition code loaded 

M Privileged-operation exception 

P Protection exception 

S Specification exception 

Y Direct control feature 

Z Protection feature 



Load PSW 
LPSW Di(Bi) 



[S'l 



82 



The double word at the location designated by the 
operand address replaces the psw. 

The operand address must have its three low-order 
bits zero to designate a double word; otherwise, a 
specification exception results in a program interrup- 
tion. 

The double word which is loaded becomes the psw 
for the next sequence of instructions. Bits 8-11 become 
the new protection key. Bits 40-63 of the double word 
become the new instruction address. The psw is not 
checked for program interruptions during the load- 
psw operation. These checks occur as part of the exe- 
cution of the next instructions. 

The interruption code in bit positions 16-31 of the 
new PSW is not retained as the psw is loaded. When 
the psw is subsequently stored because of an interrup- 
tion, these bit positions contain a new code. Similarly, 
bits 32 and 33 of the psw are not retained upon load- 
ing. They will contain the instruction-length code for 
the last-interpreted instruction when the psw is stored 
during a branch-and-link operation or during a pro- 
gram or supervisor-call interruption. 

Condition Code: The code is set according to bits 
34 and 35 of the new psw loaded. 

Program Interruptions: 
Privileged operation 
Protection ( fetch violation ) 
Addressing 
Specification 

Programming Note 

The CPU enters the problem state when load psw loads 
a double word with a one in bit position 15 and sim- 
ilarly enters the wait state if bit position 14 is one. 
The LOAD PSW is the only instruction available for 
entering the problem state or the wait state. 

Set Program Mask 
SPM R] [RR] 



04 


^1 


m 



Programming Note 

The program status is also switched by interruptions, 
initial program loading, and manual control. 



Bits 2-7 of the general register specified by the Ri field 
replace the condition code and the program mask bits 
of the current psw. 
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Bits 0, 1, and 8-31 of the register specified by the Ri 
field are ignored. The contents of the register specified 
by the Ri field remain unchanged. 

The instruction permits setting of the condition code 
and the mask bits in either the problem or supervisor 
state. 

Condition Code: The code is set according to bits 
2 and 3 of the register specified by Ri. 

Program Interruptions: None. 

Programming Note 

Bits 2-7 of the general register may have been loaded 
from the psw by branch and link. 

Set System Mask 

SSM Di(Bi) [SI] 



80 




^1 


^1 



IS 16 19 20 



The byte at the location designated by the operand 
address replaces the system mask bits of the current 

PSW. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Privileged operation 

Protection (fetch violation) 

Addressing 

Supervisor Call 

SVC I [RR] 



OA 


1 



The instruction causes a supervisor-call interruption, 
with the I field of the instruction providing the inter- 
ruption code. 

The contents of bit positions 8-15 of the instruction 
are placed in bit positions 24-31 of the old psw which 
is stored in the course of the interruption. Bit positions 
16-23 of the old psw are made zero. The old psw is 
stored at location 32, and a new psw is obtained from 
location 96. The instruction is valid in both problem 
and supervisor state. 

Condition Code: The code remains unchanged in 
the old PSW. 

Program Interruptions: None. 

Set Storage Key 
SSK Ri, Rs [RR] 



The key of the storage block addressed by the register 
designated by R2 is set according to the key in the 
register designated by Ri. 

The storage block of 2,048 bytes, located on a mul- 
tiple of the block length, is addressed by bits 8-20 of 
the register designated by the R2 field. Bits 0-7 and 
21-27 of this register are ignored. Bits 28-31 of the 
register must be zero; otherwise, a specification ex- 
ception causes a program interruption. 

The five-bit key is obtained from bits 24-28 of the 
register designated by the Ri field. Bits 0-23 and 29-31 
of this register are ignored. When fetch protection is 
not installed, bit 28 of the register specified by the Ri 
field is ignored. 

Condition Code: The code remains unchanged. 

Program Interruptions: 

Operation ( if protection feature is not installed) 

Privileged operation 

Addressing 

Specification 

Insert Storage Key 
ISK Rj, Rs [RR] 
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The key of the storage block addressed by the reg- 
ister designated by R2 is inserted in the register desig- 
nated by Ri. 

The storage block of 2,048 bytes, located on a mul- 
tiple of the block length, is addressed by bits 8-20 of 
the register designated by the R2 field. Bits 0-7 and 
21-27 of this register are ignored. Bits 28-31 of the 
register must be zero; othervnse, a specification ex- 
ception causes a program interruption. The five-bit 
key is inserted in bits 24-28 of the register specified 
by the Ri field. Bits 0-23 of this register remain un- 
changed, and bits 29-31 are set to zero. When fetch 
protection is not installed, bit 28 of the register speci- 
fied by the Ri field is set to zero. 
Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation ( if protection feature is not installed ) 

Privileged operation 

Addressing 

Specification 

Test and Set 

TS D,(B,) [SI] 
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The leftmost bit ( bit position ) of the byte located at 
the first operand address is used to set the condition 
code, and the entire addressed byte is set to all ones. 

The byte in storage is set to all ones as it is fetched 
for the testing of bit position 0. No other access to 
this location is permitted between the moment of 
fetching and the moment of storing all ones. 

The operation is terminated on any protection vio- 
lation. The condition-code setting is unpredictable 
when a protection violation occurs. 

Resulting Condition Code: 

Leftmost bit of byte specified is zero 

1 Leftmost bit of byte specified is one 

2 -- 

3 — 

Program Interruptions: 
Protection ( store or fetch violation ) 
Addressing 

Programming Note 

TEST AND SET can be used for controlled sharing of a 
common storage area by more than one program. To 
accomplish this, bit position of a byte must be 
designated as the control bit. The desired interlock 
can be achieved by establishing a program convention 
in which a zero in the bit position indicates that the 
common area is available but a one means that the 
area is being used. Each using program then must 
examine this byte by means of test and set before 
making access to the common area. If the test sets the 
condition code to zero, the area is available for use; 
if it sets the condition code to one, the area cannot be 
used. Because test and set permits no access to the 
test byte between the moment of fetching (for testing) 
and the moment of^ storing all ones (setting), the pos- 
sibility is eliminated of a second program's testing the 
byte before the first program is able to reset it. 

Write Direct 

WRD D,(B,), I, [SI] 
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The byte at the location designated by the operand 
address is made available as a set of direct-out static 
signals. Eight instruction bits are made available as 
signal-out timing signals. 

The eight data bits of the byte fetched from storage 
are presented on a set of eight direct-out lines as 
static signals. These signals remain until the next 
WRITE direct is exccutcd. No parity is presented with 
the eight data bits. 

Instruction bits 8-15, the I2 field, are made available 
simultaneously on a set of eight signal-out lines as 0.5- 
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microsecond to 1.0-microsecond timing signals. On a 
ninth line (write out) a 0.5-microsecond to 1.0-micro- 
second timing signal is made available concurrently 
with these timing signals. The eight signal-out lines 
are also used in read direct. No parity is made availa- 
ble with the eight instruction bits. 

Condition Code: The code remains unchanged. 
Program Interruptions: 

Operation (if direct control feature is not installed) 

Privileged operation 

Protection ( fetch violation ) 

Addressing 

Programming Note 

The timing signals and the write-out signal may be 
used to alert the equipment to which the data are 
sent. When data are sent to another cpu, the external 
signal interruption may be used to alert that cpu. 



Read Direct 

ROD Di(Bi), I2 



[S/] 
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Eight instruction bits are made available as signal-out 
timing signals. A direct-in data byte is accepted from 
an external device in the absence of a hold signal and 
is placed in the location designated by the operand 
address. 

Instruction bits 8-15, the I2 field, are made available 
on a set of eight signal-out lines as 0.5-microsecond to 
1.0-microsecond timing signals. These signal-out lines 
are also used in mhrite direct. On a ninth line (Read 
Out) a 0.5-microsecond to 1.0-microsecond timing 
signal is made available coincident with these timing 
signals. The read-out line is distinct from the write-out 
line in write direct. No parity is made available with 
the eight instruction bits. 

Eight data bits are accepted from a set of eight 
direct-in lines when the hold signal on the hold-in 
line is absent. The hold signal is sampled after tiie 
read-out signal has been completed and should be 
absent for at least 0.5-microsecond. No parity is ac- 
cepted with data signals, but a parity bit is generated 
as the data are placed in storage. When the hold sig- 
nal is not removed, the cpu does not complete the in- 
struction. Excessive duration of this instruction may 
result in incomplete updating of the timer. 

Condition Code: The code remains unchanged. 

Program Interruptions: 
Operation (if direct control feature is not installed) 
Privileged operation 
Protection ( store violation ) 
Addressing 
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Programming Note 

The direct-out lines of one cpu may be connected to 
the direct-in Hnes of another cpu, providing cpu-to-CPU 
static signaHng. Further, the write-out signal of the 
sending cpu may serve as the hold signal for the re- 
ceiving CPU, temporarily inhibiting a eead direct when 
the signals are in transition. 

Equipment connected to the hold-in line should be 
so constructed that the hold signal is removed when 
READ DIRECT is performed. Absence of the hold signal 
should correspond to absence of current in such a 
fashion that the cpu can proceed when power is re- 
moved from the source of the hold signal. 
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Diagnose 



5/ 
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The CPU performs built-in diagnostic functions. 

The purpose of the I2 field and the operand address 
may be defined in greater detail for a particular cpu 
and its appropriate diagnostic procedures. Similarly, 
the number of low-order address bits which must be 
zero is further specified for a particular cpu. When the 
address does not have the required number of low- 
order zeros, a specification exception causes a program 
interruption. Whether protection applies to diagnose 
depends on the model. 

The purpose of the diagnostic functions is verifica- 
tion of proper functioning of the cpu equipment and 
locating faulty components. 

The DIAGNOSE is completed either by taking the next 
sequential instruction or by obtaining a new psw from 
location 112. The diagnostic procedure may affect the 
problem, supervisor, and interruptible status of the 
CPU, the condition code, and the contents of storage, 
registers, and timer, as well as the progress of i/o 
operations. 

Some diagnostic functions turn on the test light on 
the operator control section of the system control 
panel. 

Since the instruction is not intended for problem- 
program or supervisor-program use, diagnose has no 
mnemonic. 

Condition Code: The code is unpredictable. 

Program Interruptions: 
Privileged operation 
Protection (store or fetch violation) 
Specification 
Addressing 



Status-Switching Exceptions 

Exceptional instructions, operand designations, or data 
cause a program interruption. When the interruption 
occurs, the current psw is stored as an old psw, and a 
new psw is obtained. The interruption code inserted 
in the old psw identifies the cause of the interruption. 
The following exception conditions cause a program 
interruption in status-switching operations. 

Operation: The direct control feature is not installed, 
and the instruction is read direct or write direct; or, 
the protection feature is not installed and the instruc- 
tion is set storage key or insert storage key. 

Privileged Operation: A load psw, set system mask. 



set storage key, insert storage key, write dibect, 
read direct, or diagnose is encountered while the cpu 
is in the problem state. 

Protection: The key of an operand in storage does 
not match the protection key in the psw. The instruc- 
tion is suppressed on a store violation, except for read 
DIRECT and test and set, which are terminated. The 
operation is terminated on a fetch violation. 

Addressing: An address designates a location out- 
side the available storage for the installation. The op- 
eration is terminated, except for diagnose, which is 
suppressed. 

Specification: The operand address of a load psw 
does not have all three low-order bits zero; the opcsrand 
address of diagnose does not have as many low-order 
zero bits as required for the particular cpu; the 
block address specified by set storage key or insert 
STORAGE KEY docs uot havc the four low-order bits all- 
zero; or the protection feature is not installed and a 
PSW with a nonzero protection key is introduced. 

When an instruction is suppressed, storage and ex- 
ternal signals remain unchanged, and the psw is not 
changed by information from storage. Although stor- 
age remains unchanged, read direct may have made 
a timing signal available. 

When an interruption is taken, the instruction ad- 
dress stored as part of the old psw has been updated 
by the number of halfwords indicated by the instruc- 
tion-length code in the old psw. 

Operand addresses are tested only when used to ad- 
dress storage. The address restrictions do not apply 
to the components from which an address is generated: 
the content of the Di field and the content of the 
register specified by Bi.. 

Programming Notes 

When a program interruption occurs, the current psw 
is stored in the old psw location. The instruction ad- 
dress stored as part of this old psw is thus the updated 
instruction address, having been updated by the num- 
ber of halfwords indicated in the instruction-length 
code of the same psw. The interruption code in this 
old PSW identifies the cause of the interruption and 
aids in the programmed interpretation of the old psw. 
If the new psw for a program interruption has an 
unacceptable instruction address, another program in- 
terruption occurs. Since this second program interrup- 
tion introduces the same unacceptable instruction ad- 
dress, a string of program interruptions is established 
which may be broken only by an external or i/o in- 
terruption. If these interruptions also have an unac- 
ceptable new PSW, new supervisor information must 
be introduced by initial program loading or by man- 
ual intervention. 
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The interruption system permits the cpu to change its 
state as a result of conditions external to the system, 
in i/o units, or in the cpu itself. The five classes of 
these conditions are input/output, program, super- 
visor-call, external, and machine-check interruptions. 



Interruption Action 

An interruption consists of storing the current psw as 
an old PSW and fetching a new psw. 

Processing resumes in the state indicated by the 
new PSW. The new PSW is not checked for progranv 
ming errors when it becomes the current psw. These 
checks are made when the next instruction is exe- 
cuted. The old PSW contains the address of the in- 
struction that would have been executed next if an 
interruption had not occurred and the instruction- 
length code of the last-interpreted instruction. 

Interruptions are taken only when the cpu is inter- 
ruptible for the interruption source. Input/output and 
external interruptions may be masked by the system 
mask, four of the 15 program interruptions may be 
masked by the program mask, and the machine-check 
interruptions may be masked by the machine-check 
mask. 

An interruption always takes place after one instruc- 
tion interpretation is finished and before a new in- 
struction interpretation is started. However, the oc- 
currence of an interruption may affect the execution 
of the current instruction. To permit proper program- 
med action following an interruption, the cause of the 
interruption is identified and provision is made to 
locate the last-interpreted instruction. 

When the cpu is commanded to stop, the current 
instruction is finished, and all interruptions that are 
pending or become pending before the end of the 
instruction, and which are not masked, are taken. 

The details of instruction execution, source identifi- 
cation, and location determination are explained in 
later sections and are summarized in the following 
table. 

Programming Note 

A pending interruption will be taken even if the cpu 
becomes interruptible during only one instruction. 



SOURCE 
IDENTIFICATION 

Input/Output 
Channel 
Channel 1 
Channel 2 
Channel 3 
Channel 4 
Channel 5 
Channel 6 



INTERRUPTION CODE MASK ILC OPERATION 
PSW BITS 16-31 BITS SET EXECUTION 



(old PSW 56, new PSW 120, 

00000000 aaaaaaaa 

00000001 aaaaaaaa 1 

00000010 aaaaaaaa 2 

00000011 aaaaaaaa 3 

00000100 aaaaaaaa 4 

00000101 aaaaaaaa 5 
00000110 aaaaaaaa 6 



priority 4 ) 
X completed 
completed 
completed 
completed 
completed 
completed 
completed 



Program (old PSW 40, new PSW 104, priority 2) 



Operation 
Privileged 

operation 
Execute 
Protection 



Addressing 



Specification 
Data 

Fixed-point 
overflow 
Fixed-point divide 



00000000 00000001 
00000000 00000010 

00000000 00000011 
00000000 00000100 



00000000 00000101 



00000000 00000110 
00000000 00000111 
00000000 00001000 

00000000 00001001 



Decimal overflow 
Decimal divide 
Exponent overflow 
Exponent 

underflow 
Significance 
Floating-point 

divide 



00000000 00001010 
00000000 00001011 
00000000 00001100 
00000000 00001101 

00000000 00001110 
00000000 00001111 



36 



37 



38 



39 



1,2,3 suppressed 

1.2 suppressed 

2 suppressed 
0,2,3 suppressed 
or 

terminated 
0,1,2,3 suppressed 
or 

terminated 
1,2,3 suppressed 

2.3 terminated 
1,2 completed 



1,2 



3 

3 

1,2 
1.2 



suppressed 

or 

completed 

completed 

suppressed 

terminated 

completed 



1,2 completed 
1,2 suppressed 



Supervisor Call (old PSW 32, new PSW 96, priority 2) 
Instruction bits 00000000 rrrrrrrr 1 completed 



External (old PSW 24, new PSW 88, priority 3) 



Timer 

Interrupt key 
External signal 2 
External signal 3 
External signal 4 
External signal 5 
External signal 6 
External signal 7 



00000000 Innnnnnn 7 x 

00000000 nlnnnnnn 7 x 

00000000 nnlnnnnn 7 x 

00000000 nnnlnnnn 7 x 

00000000 nnnnlnnn 7 x 

00000000 nnnnn Inn 7 x 

00000000 nnnnnnln 7 x 

00000000 nnnnnnnl 7 x 



completed 
completed 
completed 
completed 
completed 
completed 
completed 
completed 



Machine Check (old PSW 48, new PSW 112, priority 1) 

Machine 00000000 00000000 13 x terminated 

malfunction 

NOTES 

a Device address bits 

n Other external-interruption conditions 

r Bits of Ri and R2 field of supervisor call 

x Unpredictable 
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Instruction Execution 

An interruption occurs when the preceding instruction 
is finished and the next instruction is not yet started. 
The manner in which the preceding instruction is 
finished may be influenced by the cause of the inter- 
ruption. The instruction is said to have been com- 
pleted, terminated, or suppressed. 

In the case of instruction completion, results are 
stored and the condition code is set as for normal in- 
struction operation, although the result may be influ- 
enced by the exception which has occurred. 

In the case of instruction termination, all, part, or 
none of the result may be stored. Therefore, the result 
data are unpredictable. The setting of the condition 
code, if called for, may also be unpredictable. In 
general, the results should not be used for further 
computation. 

In the case of instruction suppression, the execution 
proceeds as if no operation were specified. Results 
are not stored, and the condition code is not changed. 

Source Identification 

The five classes of interruptions are distinguished by 
the storage locations in which the old psw is stored 
and from which the new psw is fetched. The detailed 
causes are further distinguished by the interruption 
code of the old psw, except for the machine-check 
interruption. The bits of the interruption code are 
numbered 16-31, according to their position in the psw. 

For i/o interruptions, additional information is pro- 
vided by the contents of the channel status word 
stored as part of the i/o interruption. 

For machine-check interruptions, additional infor- 
mation is provided by the diagnostic procedure, which 
is part of the interruption. 

The following table hsts the permanently allocated 
main-storage locations. 

H PURPOSE 

Initial program loading PSW 
Initial program loading CCWl 
Initial program loading CCW2 
External old PSW 
Supervisor call old PSW 
Program old PSW 
Machine old PSW 
Input/output old PSW 
Channel status word 
Channel address word 
Unused 
Timer 
Unused 

External new PSW 
Supervisor call new PSW 
Program new PSW 
Machine-check new PSW 
Input/output new PSW 
Diagnostic scan-out area* 
-out area depends on the par- 



ADDRESS 

0000 

8 0000 

16 0001 

24 0001 

32 0010 

40 0010 

48 0011 

56 0011 

64 0100 

72 0100 

76 0100 

80 0101 

84 0101 

88 0101 

96 0110 

104 0110 

112 0111 

120 0111 

128 1000 



0000 
1000 
0000 
1000 
0000 
1000 
0000 
1000 
0000 
1000 
1100 
0000 
0100 
1000 
0000 
1000 
0000 
1000 
0000 



Double word 
Double word 
Double word 
Double word 
Double word 
Double word 
Double word 
Double word 
Double word 
Word 
Word 
Word 
Word 

Double word 
Double word 
Double word 
Double word 
Double word 



Location Determination 

For some interruptions, it is desirable to locate the in- 
struction being interpreted when the interruption oc- 
curred. Since the instruction address in the old psw 
designates the instruction to be executed next, it is 
necessary to know the length of the preceding instruc- 
tion. This length is recorded in bit positions 32 and 
33 of the PSW as the instruction-length code. 

The instruction-length code is predictable only for 
program and supervisor-call interruptions. For i/o 
and external interruptions, the interruption is not 
caused by the last-interpreted instruction, and the 
code is not predictable for these instructions. For 
machine-check interruptions, the setting of the code 
may be affected by the malfunction and, therefore, is 
unpredictable. 

For the supervisor-call interruption, the instruction- 
length code is 1, indicating the half word length of 
SUPERVISOR CALL. For program interruptions, the codes 
1, 2, and 3 indicate the instruction length in halfwords. 
The code is reserved for program interruptions 
where the length of the instruction is not available be- 
cause of certain overlapping conditions in instruction 
fetching. In code-0 cases, the instruction address in 
the old PSW does not represent the next instruction 
address. Instruction-length code can occur for a 
program interruption only when the interruption is 
caused by a protected or an unavailable data address. 
The following table shows the states of the instruction- 
length code. 







INSTRUC- 








PSW BITS 


TION 


INSTRUCTION 




ILC 


32-33 


BITS 0-1 


LENGTH 


FORMAT 





00 




Not available 




1 


01 


00 


One halfword 


RR 


2 


10 


01 


Two halfwords 


RX 


2 


10 


10 


Two halfwords 


RS or SI 


3 


11 


11 


Three halfwords 


SS 



*The size of the diagnostic scan 
ticular model and I/O channels. 



Programming Notes 

When a program interruption is due to an incorrect 
branch address, the location determined from the in- 
struction address and instruction-length code is the 
branch address and not the location of the branch 
instruction. 

When an interruption occurs while the cpu is in the 
wait state, the instruction-length code is always unjpre- 
dictable. 

The instruction execute represents upon interrup- 
tion an instruction-length code which does not reflect 
the length of the instruction executed, but is 2, the 
length of EXECUTE. 

Input/Output Interruption 

The i/o interruption provides a means by which the 
CPU responds to signals from i/o devices. 
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A request for an i/o interruption may occur at any 
time, and more than one request may occur at the 
same time. The requests are preserved in the i/o 
section until accepted by the cpu. Priority is estab- 
lished among requests so that only one interruption 
request is processed at a time. 

An i/o interruption can occur only after execution 
of the current instruction is completed and while the 
CPU is interruptible for the channel presenting the 
request. Channels are masked by system mask bits 0-6. 
Interruptions masked oflF remain pending. 

The i/o interruption causes the old rsw to be stored 
at location 56 and causes the channel status word as- 
sociated with the interruption to be stored at location 
64. Subsequently, a new psw is loaded from location 
120. 

The interruption code in the old psw identifies the 
channel and device causing the interruption. The in- 
struction-length code is unpredictable. 

Program Interruption 

Exceptions resulting from improper specification or 
use of instructions and data cause a program interrup- 
tion. 

The current instruction is completed, terminated, or 
suppressed. Only one program interruption occurs for 
a given instruction and is identified in the old psw. 
The occurrence of a program interruption does not 
preclude the simultaneous occurrence of other pro- 
gram-interruption causes. Which of several causes is 
identified may vary from one occasion to the next and 
from one model to another. 

A program interruption can occur only when the 
corresponding mask bit, if any, is one. When the mask 
bit is zero, the interruption is ignored. Program inter- 
ruptions do not remain pending. Program mask bits 
36-39 permit masking of four of the 15 interruption 
causes. 

The program interruption causes the old psw to be 
stored at location 40 and a new psw to be fetched 
from location 104. 

The cause of the interruption is identified by the 
four low-order bit positions in the interruption code, 
PSW bits 28-31. The remainder of the interruption 
code, bits 16-27 of the psw, are made zero. The in- 
struction-length code indicates the length of the pre- 
ceding instruction in half words. For a few cases, 
the instruction length is not available. These cases are 
indicated by code 0. 

If the new psw for a program interruption has an 
unacceptable instruction address, another program in- 
terruption occurs. Since this second program interrup- 
tion introduces the same unacceptable instruction ad- 
dress, a string of program interruptions is established 



which may be broken only by an external or i/o in- 
terruption. If these interruptions also have an unac- 
ceptable new PSW, new supervisor information must 
be introduced by initial program loading or by man- 
ual intervention. 

A description of the individual program exceptions 
follows. The application of these rules to each class of 
instructions is further described in the applicable sec- 
tions. Some of the exceptions listed may also occur in 
operations executed by i/o channels. In that event, the 
exception is indicated in the channel status word 
stored with the i/o interruption (as explained under 
"Input/Output Operations"). 

Operation Exception 

When an operation code is not assigned or the as- 
signed operation is not available on the particular 
model, an operation exception is recognized. The op- 
eration is suppressed. 
The instruction-length code is 1, 2, or 3. 

Privileged-Operation Exception 

When a privileged instruction is encountered in the 
problem state, a privileged-operation exception is rec- 
ognized. The operation is suppressed. 
The instruction-length code is 1 or 2. 

Execute Exception 

When the subject instruction of execute is another 
EXECUTE, an execute exception is recognized. The 
operation is suppressed. 

The instruction-length code is 2. 

Protection Exception 

When the key of an instruction halfword or an oper- 
and in storage does not match the protection key in 
the PSW, a protection exception is recognized. 

The operation is suppressed on a store violation, ex- 
cept in the case of store multiple, read direct, test 
AND set, and variable-length operations, which are 
terminated. 

Except for execute, which is suppressed, the opera- 
tion is terminated on a fetch violation. 

The instruction-length code is 0, 2, or 3. 

Addressing Exception 

When an address specifies any part of data, an in- 
struction, or a control word outside the available 
storage for the particular installation, an addressing 
exception is recognized. 

In most cases, the operation is terminated for an in- 
valid data address. Data in storage remain unchanged, 
except when designated by valid addresses. In a few 
cases, an invalid data address causes the instruction 
to be suppressed — and (ni), exclusive or (xi), or 
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(oi), MOVE (mVi), convert TO DECIMAL, DIAGNOSE, 

EXECUTE, and certain store operations (st, stc, sth, 
STD, and ste). The operation is suppressed for an in- 
valid instruction address. 

The instruction-length code normally is 1, 2 or 3; 
but may be in the case of a data address. 

Specification Exception 

A specification exception is recognized when: 

1. A data, instruction, or control- word address does 
not specify an integral boundary for the unit of in- 
formation. 

2. The Ri field of an instruction specifies an odd 
register address for a pair of general registers that 
contains a 64-bit operand. 

3. A floating-point register address other than 0, 2, 
4, or 6 is specified. 

4. The multiplier or divisor in decimal arithmetic 
exceeds 15 digits and sign. 

5. The first operand field is shorter than or equal to 
the second operand field in decimal multiplication or 
division. 

6. The block address specified in set storage key or 
INSERT STORAGE KEY has the four low-order bits not 
all zero. 

7. A psw with a nonzero protection key is encoun- 
tered when protection is not installed. 

The operation is suppressed. The instruction-length 
code is 1, 2, or 3. 

Data Exception 

A data exception is recognized when: 

1. The sign or digit codes of operands in decimal 
arithmetic or editing operations or in convert to 
BINARY are incorrect. 

2. Fields in decimal arithmetic overlap incorrectly. 

3. The decimal multiplicand has too many high- 
order significant digits. 

The operation is terminated. The instruction-length 
code is 2 or 3. 

Fixecf-Point-Overflow Exception 

When a high-order carry occurs or high-order signifi- 
cant bits are lost in fixed-point add, subtract, shift, or 
sign-control operations, a fixed-point-overflow excep- 
tion is recognized. 

The operation is completed by ignoring the infor- 
mation placed outside the register. The interruption 
may be masked by psw bit 36. 

The instruction-length code is 1 or 2, 

Fixed-Point-Divide Exception 

A fixed-point-divide exception is recognized when a 
quotient exceeds the register size in fixed-point divi- 
sion, including division by zero, or the result of con- 
vert TO BINARY exceeds 31 bits. 



Division is suppressed. Conversion is completed by 
ignoring the information placed outside the register. 
The instruction-length code is 1 or 2. 

Decimal-Overflow Exception 

When the destination field is too small to contain the 
result field in a decimal operation, a decimal-overflow 
exception is recognized. 

The operation is completed by ignoring the overflow 
information. The interruption may be masked by psw 
bit 37. 

The instruction-length code is 3. 

Decimal-Divide Exception 

When a quotient exceeds the specified data field 
size, a decimal-divide exception is recognized. The 
operation is suppressed. 
The instruction-length code is 3. 

Exponent-Overflow Exception 

When the result characteristic exceeds 127 in floating- 
point addition, subtraction, multiplication, or division, 
an exponent-overflow exception is recognized. The 
operation is terminated. 

The instruction-length code is 1 or 2. 

Exponent-Underflow Exception 

When the result characteristic is less than zero in 
floating-point addition, subtraction, multiplication, or 
division, an exponent-underflow exception is rec- 
ognized. 

The operation is completed by making the result a 
true zero. The interruption may be masked by psw 
bit 38. 

The instruction-length code is 1 or 2. 

Significance Exception 

When the result of a floating-point addition or sub- 
traction has an all-zero fraction, a significance excep- 
tion is recognized. 

The operation is completed. The interruption may 
be masked by psw bit 39. The manner in which the 
operation is completed is determined by the mask bit. 

The instruction-length code is 1 or 2. 

Floating-Point-Divide Exception 

When division by a floating-point number with zero 
fraction is attempted, a floating-point divide exception 
is recognized. The operation is suppressed. 
The instruction-length code is 1 or 2. 

Supervisor-Call Interruption 

The supervisor-call interruption occurs as a result of 
the execution of supervisor call. 

The supervisor-call interruption causes the old psw 
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to be stored at location 32 and a new psw to be 
fetched from location 96. 

The contents of bit positions 8-15 of the supervisor 
CALL become bits 24-31 in the interruption code of the 
old PSW. PSW bit positions 16-23 in the old psw are 
made zero. The instruction-length code is 1, indicating 
the halfword length of supervisor call. 

Programming Notes 

The name "supervisor call" indicates that one of the 
major purposes of the interruption is the switching 
from problem to supervisor state. This major purpose 
does not preclude the use of this interruption for other 
types of status switching. 

The interruption code may be used to convey a 
message from the calling program to the supervisor. 

When supervisor call is performed as the subject 
instruction of execute, the instruction-length code is 2. 

External Interruption 

The external interruption provides a means by which 
the CPU responds to signals from the timer, from the 
interrupt key, and from external units. 

A request for an external interruption may occur at 
any time, and requests from different sources may 
occur at the same time. Requests are preserved until 
honored by the cpu. All pending requests are pre- 
sented simultaneously when an external interruption 
occurs. Each request is presented only once. When 
several requests from one source are made before the 
interruption is taken, only one interruption occurs. 

An external interruption can occur only when sys- 
tem mask bit 7 is one and after execution of the cur- 
rent instruction is completed. The interruption causes 
the old PSW to be stored at location 24 and a new 
PSW to be fetched from location 88. 

The source of the interruption is identified in bit 
positions 24-31 of the old psw. The remainder of the 
interruption code, psw bits 16-23, is made zero. The 
instruction-length code is unpredictable for external 
interruptions. 

Timer 

A timer value changing from positive to negative 
causes an external interruption with psw bit 24 set to 
one. 

The timer occupies a 32-bit word at main-storage 
location 80 with a format as shown in the following 
illustration. The count is treated as a signed integer by 
following the rules for fixed-point arithmetic. The neg- 
ative overflow, occurring as the timer value changes 
from a large negative number to a large positive num- 
ber, is ignored. The interruption is initiated as the 
count proceeds from a positive number, including 



zero, to a negative number. The full cycle of the timer 
is 15.5 hours. 
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In the basic form, the contents of the timer are re- 
duced by one in bit position 21 and in bit position 23 
every 1/60 of a second, or the timer contents are re- 
duced by one in bit position 21 and in bit position 22 
every 1/50 of a second. The choice is determined by 
the available line frequency. In either case, the timer 
operates as if bit position 23 were being decremented 
by one every 1/300 of a second. 

The line-frequency timer causes the word at storage 
location 80 to be updated whenever access to storage 
permits. The updating occurs only between the execu- 
tion of instructions. An updated timer value is normal- 
ly available at the end of each instruction execution, 
and, if no other activity in the system interferes with 
timer updating, any reference to the word at location 
80 yields a timer value that, within the resolution of 
the timer, is not off by more than the execution time of 
the instruction. When the execution of an instruction 
or other activity in the system causes storage updating 
to be delayed by more than one period, the content 
of the word at location 80 subsequently may be re- 
duced by more than one unit in a single updating 
cycle, depending on the length of the delay and the 
extent of timer backup storage. Timer updating may 
be omitted when i/o data transmission approaches the 
limit of storage capability, when a channel sharing cpu 
equipment and operating in burst mode causes cpu 
activity to be locked out, or when the instruction time 
for READ direct is excessive. The program is not alerted 
when omission of updating causes the real-time count 
to be lost. 

The value of the line-frequency timer is accessible 
to any reference to word location 80, provided the lo- 
cation is not protected for the type of reference. The 
32-bit timer value may be changed at any time by 
storing a new value in location 80. Fetching of location 
80 provides the current contents of bit positions 0-31. 
Bit positions 24-31 of the line-frequency timer do not 
participate in the updating, and their contents are not 
changed by the timer. 

Higher resolution of timing may be obtained in some 
models by decrementing the content of bit position 31 
approximately every 13 microseconds. The exact fre- 
quency of decrementing bit position 31 is such as to 
count at 300 cycles per second in bit position 23. 

To avoid excessive interference in main storage 
when a timer with higher resolution is provided, all or 
part of the eight-bit high-resolution portion of the 
timer may be kept in internal timer backup storage. 
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Location 80 may not be updated for each time in- 
crement, but, storage accesses permitting, updating 
occurs at least as frequently as with the line-frequency 
timer. As in the case of the line-frequency timer, when 
activity in the system has caused updating of location 
80 to be delayed, two or more contiguous updating 
cycles may occur, or, upon excessive activity, updating 
may be omitted, thus causing the real-time count to be 
lost. 

When a cpu equipped with a high-resolution timer 
addresses the timer as a source of an operand, the in- 
struction refers to both the main storage and backup 
storage portions of the timer, provided the location is 
not protected for the type of reference. All 32 bits of 
the timer may be changed by storing a new value at 
location 80, while on fetching an operand, location 80 
yields a timer value that, within the resolution of the 
timer, is not off by more than the execution time of the 
instruction. When the content of the timer is fetched 
by the channel or is used as a source of an instruction, 
the content of the low-order byte is unpredictable. 
Similarly, when the channel stores data at location 83, 
the effect of the operation on the eight low-order bits 
of the timer value is unpredictable. 

When location 80 is protected, any attempt to 
change the value of the timer causes a program inter- 
ruption with protection exception. When protection 
exception is indicated, the timer value in main storage, 
as well as in the cpu internal backup storage, remains 
unchanged. 

In a system having shared main storage, a cpu has 
access only to the main-storage part of another cpu's 
timer, provided the location is not protected for the 
type of reference. On fetching of the timer of another 
CPU, the content of the low-order byte is unpredictable 
when a high-resolution timer has been installed, where- 
as storing in the low-order byte of the timer of another 
CPU may have an unpredictable effect on the eight low- 
order bits of the timer value. 

The timer value remains unchanged during initial 
program loading when the cpu is in the stopped state, 
or when the rate switch on the operator intervention 
panel is set to instruction step. 

The timer is an optional feature on some models. 

Programming Notes 

The timer in association with a program can serve both 
as a real-time clock and as an interval timer. 

The value of the timer may be changed without 
losing the real-time count by loading the new value in 
byte locations 84-87 and then shifting bytes 80-87 into 
byte locations 76-83 by means of the instruction move, 
thus placing in a single operation the new timer value 
into word location 80 and making the old value availa- 
ble at location 76. If two instructions are used to inter- 



rogate and then replace the value of the timer, the 
program may lose a time increment if an updating 
cycle occurs between the execution of the two instruc- 
tions. 

When the value of the timer is to be recorded on an 
i/o device, the program should first store the timer 
value in a temporary storage location to which the i/o 
operation should subsequently refer. When the channel 
fetches the timer value directly from location 80, the 
value as recorded on the i/o device is unpredictable. 
The channel may fetch the information from storage a 
byte or a halfword at a time, and the cpu may update 
the contents of location 80 between channel references. 

Interrupt Key 

Pressing the interrupt key on the operator control 
section of the system control panel causes an external 
interruption with psw bit 25 set to one. 
The key is active while power is on. 

External Signal 

An external signal causes an external interruption, 
with the corresponding bit in the interruption code 
turned on. 

A total of six signal-in lines may be connected to 
the CPU for receiving external signals. The pattern 
presented in psw bit positions 26-31 depends upon the 
pattern received before the interruption is taken. Be- 
cause of circuit skew, one or more of several simul- 
taneously generated external signals may arrive at the 
CPU too late to be included in the external interruption 
resulting from the earliest signal. These late signals 
may cause another interruption to be taken. An inter- 
ruption will clear all signals concurrently if the cjpu 
was disabled for external interruptions at the time the 
signals arrived. 

The facility to accept external signals is part of the 
direct control feature. It may also be available as a 
separate feature. 

Programming Note 

The signal-in lines of one cpu may be connected to the 
signal-out timing lines of the direct control feature of 
another cpu, or the signal-in lines may be connected 
to the machine check-out lines of other cpu's. An inter- 
connection of this kind allows one cpu to interrupt an- 
other. Also, the direct-out lines of one cpu may be 
connected to the direct-in lines of the other, and vice 
versa. 

Machine-Check Interruption 

The machine-check interruption provides a means for 
recovery from and fault location of machine malfunc- 
tion. 
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When the machine-check mask bit is one, occur- 
rence of a machine check terminates the current in- 
struction, initiates an internal diagnostic procedure, 
issues a signal on the machine check-out line, and sub- 
sequently causes the machine-check interruption. 

The old psw is stored at location 48 with an inter- 
ruption code of zero. The state of the cpu is scanned 
out into the storage area, starting with location 128 
and extending through as many words as the given 
CPU requires. The new PSw is fetched from location 
112. Proper execution of these steps depends on the 
nature of the machine check. 

The machine check-out signal is provided as part of 
the multisystem feature. The signal is a 0.5-micro- 
second to 1.0-microsecond timing signal that follows 
the i/o interface line-driving and terminating specifi- 
cations. The signal is designed so that it has a high 
probability of being issued in the presence of machine 
malfunction. 

When the machine-check mask bit is zero, an at- 
tempt is made to complete the current instruction 
upon the occurrence of a machine check and to pro- 
ceed with the next sequential instruction. No diagnos- 
tic procedure, signal, or interruption occurs. 

A change in the machine-check mask bit due to the 
loading of a new PSW results in a change in the treat- 
ment of machine checks. Depending on the- nature of 
a machine check, the earlier treatment may still be in 
force for several cycles. 

Following emergency power turn-off and turn-on 
or system reset, incorrect parity may exist in storage 
or registers. Unless new information is loaded, a ma- 
chine check may occur erroneously. Once storage and 
registers are cleared, a machine check can be caused 
only by machine malfunction and never by data or in- 
structions. 

Machine checks occurring in operations executed 
by i/o channels either cause a machine-check inter- 
ruption or are recorded in the channel status word for 
that operation. 



Priority of Interruptions 

During execution of an instruction, several interrup- 
tion-causing events may occur simultaneously. The 
instruction may give rise to a program interruption, an 
external interruption may occur, a machine check may 
occur, and an i/o interruption request may be made. 
Instead of the program interruption, a supervisor-call 
interruption might occur; however, both cannot occur 
since these two interruptions are mutually exclusive. 
Simultaneous interruption requests are honored in a 
predetermined order. 



The machine-check interruption has highest priority. 
When it occurs, the current operation is terminated. 
Program and supervisor-call interruptions that would 
have occurred as a result of the current instruction are 
eliminated. Every reasonable attempt is made to limit 
the side-effects of a machine check. Normally, i/o and 
external interruptions, as well as the progress of the 
i/o data transfer and the updating of the timer, re- 
main unaffected. 

When no machine check occurs, the program inter- 
ruption or supervisor-call interruption is taken first, the 
external interruption is taken next, and the i/o inter- 
ruption is taken last. The action consists of storing the 
old PSW and fetching the new psw belonging to the 
interruption first taken. This new psw is subsequently 
stored without any instruction execution, and the next 
interruption psw is fetched. This storing and fetching 
continues until no more interruptions are to be serv- 
iced. The external and i/o interruptions are taken only 
if the immediately preceding psw indicates that the 
CPU is interruptible for these causes. 

Instruction execution is resumed using the last- 
fetched psw. The order of executing interruption sub- 
routines is therefore the reverse of the order in which 
the psw's are fetched. 

The interruption code of a new psw is not loaded 
since a new interruption code is always stored. The 
instruction-length code in a new psw is similarly ig- 
nored since it is unpredictable for all interruptions 
other than program or supervisor call. The protection 
key of a new psw is stored unchanged. When the fea- 
ture is not installed, the protection key must be zero 
when loaded. 

If the new psw for the program interruption has an 
unacceptable instruction address, another program in- 
terruption occurs. Since this second program interrup- 
tion introduces the same unacceptable instruction ad- 
dress, a string of program interruptions is established. 
This string may be broken by an external or i/o inter- 
ruption. If these interruptions also have an unaccepta- 
ble new psw, new supervisor information must be in- 
troduced by initial program loading or by manual 
intervention. 

Programming Note 

When interruption sources are not masked off, the 
order of priority in handling the interruption sub- 
routines is machine check, i/o, external, and program 
or supervisor call. This order can be changed to some 
extent by masking. The priority rule applies to inter- 
ruption requests made simultaneously. An interruption 
request made after some interruptions have already 
been taken is honored according to the priority pre- 
vailing at the moment of request. 



Interruptions 83 



Input/Output Operations 



Transfer of information to and from main storage, 
other than to or from the central processing unit or via 
the direct control path, is referred to as input and out- 
put operation. An input/output (i/o) operation in- 
volves the use of an input/output device. Input/out- 
put devices perform i/o operations under control of 
control units, which are attached to the central proc- 
essing unit (cpu) by means of channels. 

This portion of the manual describes the pro- 
grammed control of i/o devices by the channels and 
by the cpu. Formats are defined for the various types 
of i/o control information. The formats apply to all 
i/o operations, and are independent of the type of i/o 
device, its speed, or its mode of operation. 

The formats described include provision for func- 
tions unique to an i/o device, such as erase gap on a 
magnetic tape unit. The way in which a device makes 
use of the format is defined in the srl publication for 
the particular device. 

Note: This part of the manual provides detailed in- 
formation about the i/o system. A more general de- 
scription appears in the Input and Output section of 
the System Structure part of this manual. 

Attachment of Input/Output Devices 

Input/Output Devices 

Input/output devices provide external storage and a 
means of communication between data processing 
systems or between a system and its environment. 
Input/output devices include such equipment as card 
read punches, magnetic tape units, direct-access-stor- 
age devices (disks and drums), typewriter-keyboard 
devices, printers, teleprocessing devices, and process 
control equipment. 

Most types of i/o devices, such as printers, card 
equipment, or tape devices, deal directly with external 
documents, and these devices are physically distin- 
guishable and identifiable. Other types consist only of 
electronic equipment and do not directly handle 
physical recording media. The channel-to-channel 
adapter, for example, provides a channel-to-channel 
data transfer path, and the data never reach a physical 
recording medium outside main storage. Similarly, the 
IBM 2702 Transmission Control handles transmission of 
information between the data processing system and a 
remote station, and its input and output are signals on 
a transmission line. Furthermore, in this latter case, the 



2702 may be time-shared for concurrent operation of 
a number of remote stations, and the 2702 is distin- 
guished as a particular i/o device only during the time 
period associated with the operation on the corre- 
sponding remote station. 

Input/output devices ordinarily are attached to one 
control unit and are accessible from one channel. 
Switching equipment is available to make some de- 
vices accessible to two or more channels by switclung 
them between two or more control units. The time re- 
quired for switching occurs during device selection 
time and may be ignored. 

Control Units 

The control unit provides the logical capabilities nec- 
essary to operate and control an i/o device, and 
adapts the characteristics of each device to the stan- 
dard form of control provided by the channel. 

All communication between the control unit and 
the channel takes place over the i/o interface. The 
control unit accepts control signals from the channel, 
controls the timing of data transfer over the i/o inter- 
face, and provides indications concerning the status 
of the device. 

The i/o interface provides an information format 
and a signal sequence common to all i/o devices. The 
interface consists of a set of lines that can connect a 
number of control units to the channel. Except for the 
signal used to establish priority among control units, 
all communications to and from the channel occur 
over a common bus, and any signal provided by the 
channel is available to all control units. At any one 
instant, however, only one control unit is logically 
connected to the channel. 

The selection of a control unit for communication 
with the channel is controlled by a signal from the 
channel that passes serially through all control units 
and permits, sequentially, each control unit to respond 
to additional signals provided by the channel. A con- 
trol unit remains logically connected on the interface 
until it has transferred the information it needs or has, 
or until the channel signals it to disconnect, whichever 
occurs earlier. ' 

The i/o device attached to the control unit may be 
designed to perform only certain limited operations, 
or it may perform many different operations. A typical 
operation is moving the recording medium and record- 
ing data. To accomplish these functions, the device 
needs detailed signal sequences peculiar to the type 
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of device. The control unit decodes the commands 
received from the channel, interprets them for the 
particular type of device, and provides the signal se- 
quence required for execution of the operation. 

A control unit may be housed separately or it may 
be physically and logically integral with the i/o de- 
vice. In the case of most electromechanical devices, a 
well-defined interface exists between the device and 
the control unit because of the diflFerence in the type of 
equipment the control unit and the device contain. 
These electromechanical devices often are of a type 
where only one device of a group attached to a control 
unit is required to operate at a time (magnetic tape 
units or disk access mechanisms, for example), and 
the control unit is shared among a number of i/o de- 
vices. On the other hand, in electronic i/o devices 
such as the channel-to-channel adapter, the control 
unit does not have an identity of its own. 

From the user's point of view, most functions per- 
formed by the control unit can be merged with those 
performed by the i/o device. Therefore, this manual 
normally does not make specific mention of the control 
unit function; the execution of i/o operations is de- 
scribed as if the i/o devices communicated directly 
with the channel. Reference is made to the control 
unit only when emphasizing a function performed by 
it or when sharing of the control unit among a num- 
ber of devices affects the execution of i/o operations. 



Channels 

The channel directs the flow of information between 
i/o devices and main storage. It relieves the cpu of 
the task of communicating directly with the devices 
and permits data processing to proceed concurrently 
with i/o operations. 

The channel provides a standard interface for con- 
necting diflFerent types of i/o devices to the cpu and 
to main storage. It accepts control information from 
the CPU in the format supplied by the program and 
changes it into a sequence of signals acceptable to a 
control unit. After the operation with the device has 
been initiated, the cpu is released for other work and 
the channel assembles or disassembles data and syn- 
chronizes the transfer of data bytes over the interface 
with main-storage cycles. To accomplish this, the chan- 
nel maintains and updates an address and a count that 
describe the destination or source of data in main 
storage. Similarly, when an i/o device provides signals 
that should be brought to the attention of the program, 
the channel converts the signals to a format compatible 
to that used in the cpu. 

The channel contains all the common facilities for 
the control of i/o operations. When these facilities are 



provided in the form of separate autonomous equip- 
ment designed specifically to control i/o devices, i/o 
operations are completely overlapped with the activity 
in the cpu. The only main-storage cycles required 
during i/o operations in such channels are those need- 
ed to transfer data and control information to or from 
the final locations in main storage. These cycles do 
not interfere with the cpu program, except when both 
the CPU and the channel concurrently attempt to refer 
to the same main storage. 

Alternatively, the system may use to a greater or 
lesser extent the facilities of the cpu for controlling i/o 
devices. When the cpu and the channel share common 
facilities, channel operations cause interference to the 
CPU, varying in intensity from occasional delay of a 
CPU cycle through a complete lockout of cpu activity. 
The intensity depends on the extent of sharing and on 
the i/o data rate. The sharing of the facilities, how- 
ever, is accomplished automatically, and the program 
is not affected by cpu delays, except for an increase in 
execution time. 



Modes of Operation 

Data transfer between main storage and an i/o device 
occurs in one of two modes : burst or multiplex. 

In burst mode, the i/o device monopolizes the i/o 
interface and stays logically connected to the channel 
for the transfer of a burst of information. No other 
device can communicate over the interface during the 
time a burst is transferred. The burst can consist of a 
few bytes, a whole block of data, or a sequence of 
blocks with associated control and status information. 

Some channels can tolerate an absence of data 
transfer during a burst mode operation, such as occurs 
when reading a long gap on tape, for not more than 
approximately one-half minute. Equipment malfunc- 
tion may be indicated when an absence of data trans- 
fer exceeds this time. 

In multiplex mode, the facilities in the channel may 
be shared by a number of concurrently operating i/o 
devices. The multiplex mode causes all i/o operations 
to be split into short intervals of time during which 
only a segment of information is transferred over the 
interface. During an interval, only one device is logi- 
cally connected to the channel. The intervals associ- 
ated with the concurrent operation of multiple i/o de- 
vices are sequenced in response to demands from the 
devices. The channel controls are occupied with any 
one operation only for the time required to transfer a 
segment of information. The segment can consist of a 
single byte of data, a few bytes of data, a status report 
from the device, or a control sequence used for initia- 
tion of a new operation. 
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A short burst of data can be handled in either multi- 
plex or burst mode. The distinction between a short 
burst occurring in the multiplex mode and an opera- 
tion in the burst mode is in the length of the bursts. A 
channel that can operate in either mode determines its 
mode of operation by "time-out." Whenever the burst 
causes the device to be connected to the channel for 
more than approximately 100 microseconds, the chan- 
nel is considered to be operating in the burst mode. 

Operation in burst and multiplex modes is differ- 
entiated because of the way the channels respond to 
i/o instructions. A channel operating a device in the 
burst mode appears busy to new i/o instructions, 
whereas a channel operating one or more devices in 
the multiplex mode is available for initiating operation 
of another device. If a channel that can operate in 
either mode happens to be communicating with an i/o 
device at the instant a new i/o instruction is issued, 
action on the instruction is delayed by the channel 
until the current mode of operation is established by 
time-out. A new i/o operation is initiated only after 
the channel has serviced all outstanding requests for 
data transfer from devices previously placed in opera- 
tion. 

Types of Channels 

A system can be equipped with two types of channels: 
selector and multiplexor. Channels are classified ac- 
cording to the modes of operation they can sustain. A 
multiplexor channel can operate either in multiplex 
mode or in burst mode, depending upon the device. A 
selector channel operates only in burst mode. 

The channel facilities required for sustaining a 
single i/o operation are termed a subchannel. The 
subchannel consists of the channel storage used for 
recording the addresses, count, and any status and 
control information associated with the i/o operation. 
The mode in which a channel can operate depends 
upon whether it has one or more subchannels. 

The selector channel has one subchannel and always 
forces the i/o device to transfer data in the burst mode. 
The burst extends over the whole block of data, or, 
when command chaining is specified, over the whole 
sequence of blocks. The selector channel cannot per- 
form any multiplexing and therefore can be involved 
in only one data transfer operation at a time. In the 
meantime, other i/o devices attached to the channel 
can be executing previously initiated operations that 
do not involve communication with the channel, such 
as rewinding tape to load point. When the selector 
channel is not executing an operation or a chain of 
operations and is not processing an interruption, it 
monitors the attached devices for status information. 



The multiplexor channel contains multiple subchati- 
nels and can operate in either multiplex or burst mode. 
In multiplex mode, one or more devices may operate 
concurrently, each on a separate subchannel. In burst 
mode, only one device on the channel may be trans- 
ferring data. The mode of operation is determined by 
the i/o device, and the mode can change at any time. 
The data transfer associated with an operation can 
occur partially in the multiplex mode and partially in 
the burst mode. Ordinarily, devices with a high rate 
of data transfer operate with the channel in burst 
mode, and slower devices run in multiplex mode. 
Some control units have a manual switch for setting 
the mode of operation. 

Multiplexor channels vary in the number of sub- 
channels they contain. When the multiplexor channel 
operates in multiplex mode, it can sustain concurrently 
one i/o operation per subchannel, provided that the 
total load on the channel does not exceed its capacity. 
Each subchannel appears to the program as an inde- 
pendent selector channel, except for those aspects of 
communication that pertain to the physical channel 
(e.g., individual subchannels on a multiplexor c;han- 
nel are not distinguished as such by the test channel 
instruction or by the mask controlling i/o interruptions 
from the channel). When the multiplexor channel is 
not servicing an i/o device, it monitors its devices for 
data and for interruption conditions. 

When the multiplexor channel is transferring data 
in burst mode, the subchannel associated with the 
burst operation monopolizes the data transfer facilities 
of the channel. Other subchannels on the multiplexor 
channel cannot respond to requests from devices until 
the burst is completed. 

Subchannels on the multiplexor channel may be 
cither nonshared or shared. 

A subchannel is referred to as nonshared if it is asso- 
ciated and can be used only with a single i/o device. 
A nonshared subchannel is used with devices that do 
not have any restrictions on the concurrency of data 
transfer, such as the ibm 1442 Card Read Punch Model 
Nl or the ibm 2250 Display Unit Model 1. 

A subchannel is referred to as shared if data transfer 
to or from a set of devices implies the use of the same 
subchannel. Only one device associated with a shared 
subchannel may be involved in data transmission at a 
time. Shared subchannels are used with devices, such 
as magnetic tape units or disk access mechanisms, 
that share a control unit. For such devices, the sharing 
of the subchannel does not restrict the concurrency of 
i/o operations since the control unit permits only one 
device to be involved in a data-transfer operation at a 
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time. A subchannel is not necessarily shared, however, 
even when the i/o devices share a control unit. For 
example, each transmission line attached to the ibm 
2702 Transmission Control is assigned a nonshared 
subchannel, although all of the transmission lines 
share the common control unit. 

System Operation 

Input/output operations are initiated and controlled 
by information with three types of formats: instruc- 
tions, commands, and orders. Instructions are decoded 
by the cpu and are part of the cpu program. Com- 
mands are decoded and executed by the channels and 
i/o devices, and initiate i/o operations, such as reading 
and writing. One or more commands arranged for se- 
quential execution form a channel program. Both in- 
structions and commands are fetched from main 
storage and are common to all types of i/o devices, 
although the modifier bits in the command code may 
specify device-dependent conditions for the execution 
of a data-transfer operation at the device. 

Functions peculiar to a device, such as rewinding 
tape or positioning the access mechanism on a disk 
drive, are specified by orders. Orders are decoded and 
executed by i/o devices. The control information 
specifying an order may appear in the modifier bits of 
a control command code, may be transferred to the 
device as data during a control or write operation, or 
may be made available to the device by other means. 

The CPU program initiates i/o operations with the 
instruction start i/o. This instruction identifies the 
channel and device and causes the channel to fetch 
the channel address word ( caw ) from a fixed location 
in main storage. The caw contains the protection key 
and designates the location in main storage from 
which the channel subsequently fetches the first chan- 
nel command word (ccw). The ccw specifies the com- 
mand to be executed and the storage area, if any, to 
be used. 

If the channel is not operating in burst mode and if 
the subchannel associated with the addressed i/o de- 
vice is not busy, the channel attempts to select the 
device by sending the address of the device to all con- 
trol units attached to the channel. A control unit that 
recognizes the address connects itself logically to the 
channel and responds to its selection by returning its 
address. The channel subsequently sends the command 
code part of the ccw over the interface, and the device 
responds with a status byte indicating whether it can 
execute the command. 

At this time, the execution of start i/o is termi- 
nated. The results of the attempt to initiate the execu- 
tion of the command are indicated by setting the 
condition code in the program status word (psw), 



and, under certain conditions, by storing pertinent in- 
formation in the channel status word (csw). 

If the operation is initiated at the device and its 
execution involves transfer of data, the subchannel 
is set up to respond to service requests from the device 
and assumes further control of the operation. In the 
case of operations that do not require any data to be 
transferred to or from the device, the device may 
signal the end of the operation immediately on receipt 
of the command code. 

An i/o operation may involve transfer of data to one 
storage area, designated by a single ccw, or to a num- 
ber of noncontiguous storage areas. In the latter case, 
a list of ccw's is used for execution of the i/o opera- 
tion, each ccw designating a contiguous storage area, 
and the ccw's are said to be coupled by data chaining. 
Data chaining is specified by a flag in the ccw and 
causes the channel to fetch another ccw upon the ex- 
haustion or filling of the storage area designated by 
the current ccw. The storage area designated by a ccw 
fetched on data chaining pertains to the i/o operation 
already in progress at the i/o device, and the i/o de- 
vice is not notified when a new ccw is fetched. Pro- 
vision is made in the ccw format for the programmer 
to specify that, when the ccw is decoded, the channel 
request an i/o interruption as soon as possible, thereby 
notifying the cpu program that chaining has pro- 
gressed to a particular ccw in the channel program. 

Termination of the i/o operation normally is indi- 
cated by two conditions: channel end and device end. 
The channel-end condition indicates that the i/o de- 
vice has received or provided all information associ- 
ated with the operation and no longer needs channel 
facilities. The device-end signal indicates that the 
i/o device has terminated execution of the operation. 
The device-end condition can occur concurrently with 
the channel-end condition or later. 

Operations that keep the control unit busy after re- 
leasing channel facilities may, under certain conditions, 
cause a third type of signal. This signal, called control 
unit end, may occur only after channel end and indi- 
cates that the control unit has become available for 
initiation of another operation. 

The conditions signaling the termination of an i/o 
operation can be brought to the attention of the pro- 
gram by i/o interruptions or, when the channel is 
masked, by programmed interrogation of the i/o de- 
vice. In either case, these conditions cause storing the 
csw, which contains additional information concern- 
ing the execution of the operation. At the time the 
channel-end condition is generated, the channel identi- 
fies to the program the last ccw used and provides its 
residual byte count, thus indicating the extent of main 
storage used. Both the channel and the device can 
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provide indications of unusual conditions with chan- 
nel end. The control-unit-end and device-end condi- 
tions can be accompanied by error indications from 
the device. 

Facilities are provided for the program to initiate 
execution of a chain of i/o operations with a single 
START i/o. When the chaining flags in the current ccw 
specify command chaining and no unusual conditions 
have been detected in the operation, the receipt of the 
device-end signal causes the channel to fetch a new 
ccw and to initiate a new command at the device. A 
chained command is initiated by means of the same 
sequence of signals over the i/o interface as the first 
command specified by start i/o. The ending signals 
occurring at the termination of an operation caused by 
a ccw specifying command chaining are not made 
available to the program when another operation is 
initiated by the command chaining; the channel con- 
tinues execution of the channel program. If, however, 
an unusual condition has been detected, the ending 
signals cause suppression of command chaining and 
termination of the channel program. 

Conditions that initiate i/o interruptions are asyn- 
chronous to activity in the cpu, and more than one 
condition can occur at the same time. The channel and 
the CPU establish priority among the conditions so that 
only one interruption request is processed at a time. 
The conditions are preserved in the i/o devices and 
subchannels until accepted by the cpu. 

Execution of an i/o operation or chain of operations 
thus involves up to four levels of participation: 

1. Except for the effects caused by the integration 
of CPU and channel equipment, the cpu is busy for the 
duration of execution of start i/o, which lasts at most 
until the addressed i/o device responds to the first 
command. 

2. The subchannel is busy with the execution from 
the initiation of the operation at the i/o device until 
the channel-end condition for the last operation of the 
command chain is accepted by the cpu. 

3. The control unit may remain busy after the sub- 
channel has been released and may generate the con- 
trol-unit-end condition when it becomes free. 

4. The i/o device is busy from the initiation of the 
first command until the device-end condition associ- 
ated with the last operation is accepted or cleared by 
the CPU. 

A pending device-end condition causes the associ- 
ated device to appear busy, but does not affect the 
state of any other part of the system. A pending control 
unit end blocks communications through the control 
unit to any device attached to it, and a pending chan- 
nel end normally blocks all communications through 
the subchannel. 



Compatibility of Operation 

The organization of the i/o system provides for a uni- 
form method of controlling i/o operations. The capa- 
bility of a channel, however, depends on its use and on 
the model to which it belongs. Channels are provided 
with different data-transfer capabilities, and an i/o 
device designed to transfer data only at a specific rate 
(a magnetic tape unit or a disk storage, for example) 
can operate only on a channel that can accommodate 
at least this data rate. 

The data rate a channel can accommodate dep(;nds 
also on the way the i/o operation is programmed. The 
channel can sustain its highest data rate when no data 
chaining is specified. Data chaining reduces the maxi- 
mum allowable rate, and the extent of the reduction 
depends on the frequency at which new ccw's are 
fetched and on the address resolution of the first byte 
in the new main-storage area. Furthermore, since in 
most instances the channel may share main storage 
with the CPU and other channels, activity in the rest of 
the system affects the accessibility of main storage and, 
hence, the instantaneous load the channel can sustain. 

In view of the dependence of channel capacity on 
programming and on activity in the rest of the system, 
an evaluation of the ability of a specific i/o configu- 
ration to function concurrently must be based on a 
consideration of both the data rate and the way the 
i/o operations are programmed. Two systems employ- 
ing identical complements of i/o devices may be able 
to execute certain programs in common, but it is pos- 
sible that other programs requiring, for example, data 
chaining, may not run on one of the systems because 
of the increased load caused by the data chaining. 

Control of Input/Output Devices 

The CPU controls i/o operations by means of four i/o 
instructions: start i/o, test i/o, halt i/o, and 'oest 

CHANNEL. 

The instruction test channel addresses a channel; 
it does not address an i/o device. The other three i/o 
instructions address a channel and a device on that 
channel. 

Input/ Output Device Addressing 

An i/o device and the associated access path are desig- 
nated by an i/o address. The i/o address is a 16-bit 
binary number and consists of two parts: a chaimel 
address in the eight high-order bit positions and a de- 
vice address in the eight low-order bit positions. 

The channel-address field provides for identifj/ing 
up to 256 channels, out of which only channels 0-6 may 
be installed; channel-addresses 7 and up are con- 
sidered invalid. Channel is a multiplexor channel; 
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channels numbered 1-6 may be either multiplexor or 
selector channels, as shown below. The number and 
type of channels available, as well as their address 
assignment, depend on the system model and the 
particular installation. 



ADDRESS 




Channel 


Device 


ASSIGNMENT 


0000 0000 


xxxx xxxx 


Devices on channel 


0000 0001 


xxxx xxxx 


Devices on channel 1 


0000 0010 


xxxx xxxx 


Devices on channel 2 


0000 0011 


xxxx xxxx 


Devices on channel 3 


0000 0100 


xxxx xxxx 


Devices on channel 4 


0000 0101 


xxxx xxxx 


Devices on channel 5 


0000 Olio 


xxxx xxxx 


Devices on channel 6 


0000 0111 


xxxx xxxx^ 




TO 


y 


INVALID 



1111 1111 



xxxx xxxx 



The device address identifies the particular i/o de- 
vice and control unit on the designated channel. The 
address identifies, for example, a particular magnetic 
tape drive, disk access mechanism, or transmission line. 
Any number in the range 0-255 can be used as a device 
address, providing facilities for addressing up to 256 
devices per channel. 

On the'^ multiplexor channel, the device address 
identifies the subchannel as well as the i/o device and 
control unit. Addresses with a "zero" in the high-order 
bit position of the device-address field pertain to sub- 
channels that are not shared. Each nonshared subchan- 
nel is identified by a unique device address. Addresses 
with a "one" in the high-order bit position may desig- 
nate either a shared or a nonshared subchannel. Shared 
subchannels are assigned sets of contiguous addresses, 
the number of addresses within the set being a power 
of two, and the first address within the set being a 
multiple of the set size. When a multiplexor channel 
has both shared and nonshared subchannels in the ad- 
dress range 128-255 (high-order bit is one), the non- 
shared subchannels are assigned lower addresses than 
the shared subchannels. The number and the type of 
subchannels available on a particular multiplexor chan- 
nel and their address assignment depend on the sys- 
tem model and the installation. 

Devices that do not share a control unit with other 
devices may be assigned any device address in the 
range 0-255, provided the address is not recognized by 
any other control unit. Logically, such devices are not 
distinguishable from their control unit, and both are 
identified by the same address. 

Devices sharing a control unit (i.e., magnetic tape 
drives or disk access mechanisms) are assigned ad- 
dresses within sets of contiguous numbers. The size of 
such a set is equal to the maximum number of devices 
that can share the control unit, or 16, whichever is 
smaller. Furthermore, such a set starts with an address 
in which the number of low-order zeros is at least 



equal to the number of bit positions required for speci- 
fying the set size. The high-order bit positions of an 
address within such a set identify the control unit, and 
the low-order bit positions designate the device on the 
control unit. 

Control units designed to accommodate more than 
16 devices (i.e., ibm 2702 Transmission Control) may 
be assigned nonsequential sets of addresses, each set 
consisting of 16, or the number required to bring the 
total number of assigned addresses equal to the maxi- 
mum number of devices attachable to the control unit, 
whichever is smaller. The addressing facilities are 
added in increments of a set so that the number of de- 
vice addresses assigned to a control unit does not ex- 
ceed the number of devices attached by more than 15. 

The control unit does not respond to any address 
outside its assigned set or sets. For example, if a con- 
trol unit is designed to control devices having only 
bits 0000-1001 in the low-order positions of the device 
address, it does not recognize addresses containing 
1010-1111 in these bit positions. On the other hand, a 
control unit responds to all addresses in the assigned 
set, regardless of whether the device associated with 
the address is installed. For example, the ibm 2803 
Tape Control with four tape units installed, and not 
equipped with the 16-drive addressing feature re- 
sponds to all of the eight addresses within the set as- 
signed to it. If no control unit responds to an address, 
the i/o device appears not operational. If a control 
unit responds to an address for which no device is in- 
stalled, the absent device appears in the not-ready 
state. 

Input/output devices accessible through more than 
one channel have a distinct address for each path of 
communications. This address identifies the channel, 
the subchannel, and the control unit. For sets of de- 
vices connected to two or more control units, the por- 
tion of the address identifying the device on the con- 
trol unit is fixed, and does not depend on the path of 
communications. 

Except for the rules described, the assignment of 
channel and device addresses is arbitrary. The assign- 
ment is made at the time of installation, and the ad- 
dresses normally remain fixed thereafter. 

States of the Input/ Output System 

The state of the i/o system identified by an i/o ad- 
dress depends on the collective state of the channel, 
subchannel, and i/o device. Each of these components 
of the i/o system can have up to four states, as far as 
the response to an i/o instruction is concerned. These 
states are listed in the following table. The name of 
the state is followed by its abbreviation and a brief 
definition. 
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CHANNEL ABBREV DEFINITION 

Available A None of the following states 

Interruption pending I Interruption immediately available 

from channel 
Working W Channel operating in burst mode 

Not operational N Channel not operational 

SITBCHANNEL ABBREV DEFINmON 

Available A None of the following states 

Interruption pending I Information for CSW available in 

subchannel 
Working W Subchannel executing an operation 

Not operational N Subchannel not operational 

I/O DEVICE ABBREV DEFINITION 

Available A None of the following states 

Interruption pending I Interruption condition pending in 

device 
Working W Device executing an operation 

Not operational N Device not operational 

A channel, subchannel, or i/o device that is avail- 
able, that contains a pending interruption condition, or 
that is working, is said to be operational. The states of 
containing an interruption condition, working, or be- 
ing not operational are collectively referred to as "not 
available." 

In the case of the multiplexor channel, the channel 
and subchannel are easily distinguishable and, if the 
channel is operational, any combination of channel and 
subchannel states are possible. Since the selector chan- 
nel can have only one subchannel, the channel and 
subchannel are functionally coupled, and certain states 
of the channel are related to those of the subchannel. 
In particular, the working state can occur only concur- 
rently in both the channel and subchannel and, when- 
ever an interruption condition is pending in the sub- 
channel, the channel also is in the same state. The 
channel and subchannel, however, are not synony- 
mous, and an interruption condition not associated 
with data transfer, such as attention, does not aflFect 
the state of the subchannel. Thus, the subchannel may 
be available when the channel has an interruption 
condition pending. Consistent distinction between the 
subchannel and channel permits the two types of chan- 
nels, selector and multiplexor, to be covered uniformly 
by a single description. 

The device referred to in the preceding table in- 
cludes both the device proper and its control unit. For 
some types of devices, such as magnetic tape units, the 
working and the interruption-pending states can be 
caused by activity in the addressed device or control 
unit. A shared control unit imposes its state on all de- 
vices attached to the control unit. The states of the de- 
vices are not related to those of the channel and sub- 
channel. 

When the response to an i/o instruction is deter- 
mined on the basis of the states of the channel and 
subchannel, the components further removed are not 
interrogated. Thus, ten composite states are identified 



as conditions for the execution of the i/o instruction. 
Each composite state is idenyfied in the following dis- 
cussion by three alphabetic characters; the first char- 
acter position identifies the state of the channel, the 
second identifies the state of the su\>channel, and the 
third refers to the state of the device. Each character 
position can contain a, i ,w, or n, denoting the state 
of the component. The symbol x in place of a letter 
indicates that the state of the corresponding compo- 
nent is not significant for the execution of the in- 
struction. 

Available (AAA): The addressed channel, subchan- 
nel, control unit, and i/o device are operational, are 
not engaged in the execution of any previously initi- 
ated operations, and do not contain any pending in- 
terruption conditions. 

Interruption Pending in Device (AAI) or Device 
Working (AAW): The addressed channel and subchan- 
nel are available. The addressed control unit or i/o de- 
vice is executing a previously initiated operation or 
contains a pending interruption conditon. These situa- 
tions are possible: 

1. The device is executing an operation after sig- 
naling the channel-end condition, such as rewinding 
tape or seeking on a disk file. 

2. The control unit associated with the device is 
executing an operation after signaling the channel- 
end condition, such as backspacing file on a magnetic 
tape unit. 

3. The device or control unit is executing an opera- 
tion on another subchannel or channel. 

4. The device or control unit contains the device- 
end, control-unit-end, or attention condition or, on 
the selector channel, the channel-end condition as- 
sociated with an operation terminated by halt i/o. 

Device Not Operational (AAN): The addressed 
channel and subchannel are available. The addressed 
i/o device is not operational. A device appears not 
operational when no control unit recognizes the ad- 
dress. This occurs when the control unit is not pro- 
vided in the system, when power is off in the control 
unit, or when the control unit has been logically 
switched off the i/o interface. The not-operational 
state is indicated also when the control unit is ]3ro- 
vided and is designed to attach the device, but the 
device has not been installed and the address has not 
been assigned to the control unit (for example, the 
second set of lines on the ibm 2702 Transmission Con- 
trol). See also "Input/Output Device Addressing." 

If the addressed device is not installed or has been 
logically removed from the control unit, but the associ- 
ated control unit is operational and the address has 
been assigned to the control unit ( for example, access 
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mechanism 7 on the ibm 2841 Storage Control that has 
only access mechanism 0-3 installed) the device is 
said to be not-ready. When an instruction is addressed 
to a device in the not-ready state, the control unit re- 
sponds to the selection and indicates unit check when- 
ever the not-ready state precludes a successful execu- 
tion of the operation. See "Unit Check." 

Interruption Pending In Subchannel (AIX): The ad- 
dressed channel is available. An interruption condition 
is pending in the addressed subchannel because of the 
termination of the portion of the operation involving 
the use of channel facilities. The subchannel is in a 
position to provide information for a complete csw. 
The interruption condition can indicate termination of 
an operation at the addressed i/o device or at another 
device on the subchannel. The state of the addressed 
device is not significant, except when test i/o is ad- 
dressed to the device associated with the terminated 
operation, in which case the csw contains status in- 
formation provided by the device. 

The state aix does not occur on the selector channel. 
On the selector channel, the existence of an interrup- 
tion condition in the subchannel immediately causes 
the channel to assign to this condition the highest 
priority for i/o interruptions and, hence, leads to the 
state iix. 

Subchannel Working, (AWX): The addressed chan- 
nel is available. The addressed subcharmel is executing 
a previously initiated operation or chain of operations 
in the multiplex mode and has not yet reached the 
channel end for the last operation. The state of the ad- 
dressed device is not significant, except when halt i/o 
is issued, in which case the csw contains status pro- 
vided by the device. 

The subchannel-working state does not occur on the 
selector channel since all operations on the selector 
channel are executed in the burst mode and cause the 
channel to be in the working state (wwx). 

Subchannel Not Operational (ANX): The addressed 
channel is available. The addressed subchannel on the 
multiplexor channel is not operational. A subchannel 
is not operational when it is not provided in the sys- 
tem. This state cannot occur on the selector channel. 

Interruption Pending in Channel (IXX): The ad- 
dressed channel is not working and has established 
which device will cause the next i/o interruption from 
this channel. The state where the channel contains a 
pending interruption condition is distinguished only 
by the instruction test channel. This instruction does 
not cause the subchannel and i/o device to be interro- 
gated. The other i/o instructions consider the chan- 
nel available when it contains a pending interruption 
condition. When the channel assigns priority for inter- 
ruption among devices, the interruption condition is 



preserved in the i/o device or subchannel. ( See "Inter- 
ruption Conditions.") 

Channel Worldng (WXX): The addressed channel 
is operating in the burst mode. In the case of the 
multiplexor channel, a burst of bytes is currently 
being handled. In the case of the selector channel, an 
operation or a chain of operations is currently being 
executed, and the channel end for the last operation 
has not yet been reached. The states of the addressed 
device and, in the case of the multiplexor channel, 
of the subchannel are not significant. 

Channel Not Operational (NXX): The addressed 
channel is not operational, or the channel address in 
the instruction is invalid. A channel is not operational 
when it is not provided in the system, when power is 
off in the channel, or when it has been switched to the 
test mode. The states of the addressed i/o device and 
subchannel are not significant. 

Resetting of the Input/ Output System 

Two types of resetting can occur in the i/o system. 
The reset states overlap the hierarchy of states distin- 
guished for the purpose of responding to the cpu 
during the execution of i/o instructions. Resetting ter- 
minates the current operation, disconnects the device 
from the channel, and may place the device in cer- 
tain modes of operation. The meaning of the two 
reset states for each type of i/o device is specified in 
the Systems Reference Library (srl) publication for 
the device. 

System Reset 

The system-reset function is performed when the 
system-reset or load key is pushed, or when a system 
power-on sequence is completed. 

System reset causes the channel to terminate opera- 
tions on all subchannels. Status information and in- 
terruption conditions in the subchannels are reset, and 
all operational subchannels are placed in the available 
state. The channel sends the system-reset signal to all 
i/o devices attached to it. 

If the device is currently communicating over the 
i/o interface, the device immediately disconnects 
from the channel. Data transfer and any operation 
using the facilities of the control unit are immediately 
terminated, and the i/o device is not necessarily posi- 
tioned at the beginning of a block. Mechanical mo- 
tion not involving the use of the control unit, such as 
rewinding magnetic tape or positioning a disk access 
mechanism, proceeds to the normal stopping point, if 
possible. The device appears in the working state until 
the termination of mechanical motion or the inherent 
cycle of operation, if any, whereupon it becomes 
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available}. Status information in the device and con- 
trol unit is reset, and no interruption condition is gen- 
erated upon completing the operation. 

A control unit accessible by more than one channel 
is reset if it is currently associated with a channel on 
the CPU generating the reset. 

Malfunction Reset 

The malfunction-reset function is performed when the 
channel detects equipment malfunctioning. 

Execution of malfunction reset in the channel de- 
pends on the type of malfunction and the model It 
may cause all operations in the channel to be termi- 
nated and all operational subchannels to be reset to 
the available state. The channel may send either the 
malfunction-reset signal to the device connected to the 
channel at the time the malfunctioning is detected, 
or channels sharing common equipment with the 
CPU may send the system-reset signal to all devices 
attached to the channel. 

When the channel signals malfunction reset over 
the interface, the device immediately disconnects 
from the channel. Data transfer and any operation 
using the facilities of the control unit are immediately 
terminated, and the i/o device is not necessarily po- 
sitioned at the beginning of a block. Mechanical mo- 
tion not involving the control unit, such as rewinding 
magnetic tape or positioning a disk access mechanism, 
proceeds to the normal stopping point, if possible. 
The device appears in the working state until the 
termination of mechanical motion or the inherent cycle 
of operation, if any. Status information associated with 
the addressed device is reset, but an interruption con- 
dition may be generated upon completing any me- 
chanical operation. 

When a malfunction reset occurs, the program is 
alerted by an i/o interruption or, when the malfunc- 
tion is detected during the execution of an i/o instruc- 
tion, by the setting of the condition code. In either 
case the csw identifies the condition. The device ad- 
dressed by the i/o instruction or the device identified 
by the i/o interruption, however, is not necessarily 
the one placed in the malfunction-reset state. In chan- 
nels sharing common equipment with the cpu, mal- 
functioning detected by the channel may be indicated 
by a machine-check interruption, in which case a csw 
is not stored and a device is not identified. The 
method of identifying malfunctioning depends upon 
the model. 

Condition Code 

The results of certain tests by the channel and device, 
and the original state of the addressed part of the i/o 
system are used during the execution of an i/o in- 



STAHT TEST HALT TEST 


I/O I/O 


I/O <:han 


0,1* 


1* 


1* 1* 


1* 


1* 1* 


1* 


3 3 


3 



struction to set one of four condition codes in bit 
positions 34 and 35 of the psw. The condition code 
is set at the time the execution of the instruction is 
completed, that is, the time the cpu is released to 
proceed with the next instruction. The condition code 
indicates whether or not the channel has performed 
the function specified by the instruction and, if not, 
the reason for the rejection. Immediately subsequent 
branch-on-condition operations can use the code for 
decision-making. 

The following table lists the conditions that are 
identified and the corresponding condition codes for 
each instruction. The states of the system and their 
abbreviations were previously defined in "States of the 
Input/Output System." The digits in the table repre- 
sent the numeric value of the code. The instruction 
START i/o can set code or 1 for the aaa state, de- 
pending on the type of operation that is initiated. 

CONDFTION CODE FOR 
CONDITIONS 

Available AAA 

Interruption pend. in device A A I 

Device working A A W 

Device not operational A A N 

Interruption pend. in subchannel A I X t 

For the addressed device 2 1*0 

For another device 2 2 

Subchannel working AWXt2 2 1* 

Subchannel not operational ANXt3 3 3 

Interruption pend. in channel I X X f see note below 1 
Channel working WXXt2 2 2 2 

Channel not operational NXXt3 3 3 3 

Error 

Channel equipment error 1* 1* 1* — 

Channel programming error 1* — — — 

Device error 1* 1* — — 

*The CSW or its status portion is stored at location 64 during 
execution of the instruction. 

tThe symbol X stands for A, I, W, and N, and indicates that 
the state of the corresponding component is not significant. 
As an example, AIX denotes the states AIA, All, AIW, and 
AIN, while IXX represents a total of 16 states, some of which 
do not occur. 

—The condition cannot be identified during execution of the in- 
struction. 

Note: For the purpose of executing START I/O, TEST I/O, 
and HALT I/O, a channel containing a pending interru]5tion 
condition appears the same as an available channel, and the 
condition-code setting depends upon the states of the sub- 
channel and device. The condition codes for the IXX states are 
the same as for the AXX states, where the X's represent: the 
states of the subchannel and the device. As an example., the 
condition-code for the lAA state is the same as for the AAA 
state, and the condition code for the I AW state is the same as 
for the A AW state. 

The available condition is indicated only when no 
errors are detected during the execution of the i/o 
instruction. When a programming error occurs in the 
information placed in the caw or ccw and the ad- 
dressed channel or subchannel is working, either con- 
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dition code 1 or 2 may be set, depending upon the 
model. Similarly, either code 1 or 3 may be set when 
a programming error occurs and a part of the ad- 
dressed i/o system is not operational. 

When a subchannel on the multiplexor channel con- 
tains a pending interruption condition (state aix), 
the i/o device associated with the terminated opera- 
tion normally is in the interruption-pending state. 
When the channel detects during execution of test 
i/o that the device is not operational, condition code 
3 is set. Similarly, condition code 3 is set when halt 
i/o is addressed to a subchannel in the working state 
and operating in the multiplex mode (state awx), 
but the device turns out to be not operational. The 
not-operational state in both situations can be caused 
by operator intervention or by machine malfunction- 
ing. 

The error conditions listed in the preceding table 
include all equipment or programming errors detected 
by the channel or the i/o device during execution of 
the i/o instruction. Except for channel equipment er- 
rors, in which case, depending on the model, machine 
check may be indicated and no csw may be stored, the 
status portion of the csw identifies the error. Three 
types of errors can occur: 

Channel Equipment Error: The channel can detect 
the following equipment errors during execution of 
START i/o, TEST i/o, and halt i/o: 

1. The device address that the channel received on 
the interface during initial selection either has a 
parity error or is not the same as the one the channel 
sent out. Some device other than the one addressed 
may be malfunctioning. 

2. The unit-status byte that the channel received on 
the interface during initial selection has a parity error. 

3. A signal from the i/o device occurred during 
initial selection at an invalid time or had invalid 
duration. 

4. The channel detected an error in its control 
equipment. 

The channel may perform the malfunction-reset 
function, depending on the type of error and the 
model. If a csw is stored, channel control check or 
interface control check is indicated, depending on the 
type of error. 

Channel Programming Error: The channel can de- 
tect the following programming errors during execu- 
tion of start i/o: 

1. Invalid ccw address in caw 

2. Invalid ccw address specification in caw 

3. Invalid storage protection key in caw 

4. Invalid caw format 

5. Location of first ccw protected for fetching 

6. First ccw specifies transfer in channel 



7. Invalid command code in first ccw 

8. Initial data address exceeds addressing capacity 
of model (see "Definition of Storage Area") 

9. Invalid count in first ccw 
10. Invalid format of first ccw 

The csw indicates program check, except for condi- 
tion 5, in which case protection check is indicated. 

Device Error: Programming or equipment errors 
detected by the device during the execution of start 
i/o are indicated by unit check or unit exception in 
the csw. 

The conditions responsible for unit check and unit 
exception for each type of i/o device are detailed in 
the SRL publication for the device. 

Instruction Format 

All i/o instructions use the following si format: 



Op Code 


^mm^. 


'^ 


^1 



Bit positions 8-15 of the instruction are ignored. 
The content of the Bi field designates a register. The 
sum obtained by the addition of the content of reg- 
ister Bi and content of the Di field identifies the 
channel and the i/o device. This sum has the format: 
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Channel 
Address 


Device 
Address 



Bit positions 0-7 are not part of the address. Bit 
positions 8-15, which constitute the high-order portion 
of the address, are ignored. Bit positions 16-23 of the 
sum contain the channel address, while bit positions 
24-31 identify the device on the channel and, addition- 
ally in the case of the multiplexor channel, the sub- 
channel. 

Note: In the detailed descriptions of the individual 
instructions, the mnemonic and the symbolic operand 
designation for the ibm System/360 assembly language 
are shown with each instruction. In the case of start 
i/o, for example, sio is the mnemonic and Di (Bi) the 
operand designation. 

Instructions 

The mnemonics, format, and operation codes of the 
i/o instructions follow. The table also indicates that 
all i/o instructions cause program interruption when 
they are encountered in the problem state, and that 
all i/o instructions set the condition code. 



NAME 


MNEMONIC 


TYPE 


EXCEPTION 


CODE 


Start I/O 


SIO 


SI, c 


M 


9C 


Test I/O 


TIO 


SI,C 


M 


9D 


Halt I/O 


HIO 


SI,C 


M 


9E 


Test Channel 


TCH 


SI,C 


M 


9F 


NOTES 











C Condition code is set 

M Privileged-operation exception 
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Programming Note 

The instructions start i/o, test i/o, and halt i/o 
may cause a csw to be stored. To prevent the con- 
tents of the csw stored by the instruction from being 
destroyed by an immediately following i/o interrup- 
tion, all channels must be masked before issuing 
start i/o, test i/o, or halt i/o and must remain 
masked until the information in the csw provided by 
the instruction has been acted upon or stored else- 
where for later use. 



Start I/O 

S/O Di(Bi) 



m 



9C 




\ 


^1 



A write, read, read backward, control or sense opera- 
tion is initiated at the addressed i/o device and sub- 
channel. The instruction start i/o is executed only 
when the cpu is in the supervisor state. 

Bit positions 16-31 of the sum formed by the addi- 
tion of the content of register Bi and the content of 
the Di field identify the channel, subchannel, and i/o 
device to which the instruction applies. The caw at 
location 72 contains the protection key for the sub- 
channel and the address of the first ccw. The ccw so 
designated specifies the operation to be performed. 
the main-storage area to be used, and the action to 
be taken when the operation is completed. 

The i/o operation specified by start i/o is initiated 
if the addressed i/o device and subchannel are avail- 
able, the channel is available or is in the interruption- 
pending state, and errors or exceptional conditions 
have not been detected. The i/o operation is not ini- 
tiated when the addressed part of the i/o system is in 
any other state or when the channel or device detects 
any error or exceptional condition during execution of 
the instruction. 

When any of the following conditions occurs, with 
the channel either available or in the interruption- 
pending state and with the subchannel available be- 
fore the execution of the instruction, start i/o causes 
the status portion, bit positions 32-47, of the csw at 
location 64 to be replaced by a new set of status bits. 
The status bits pertain to the device addressed by the 
instruction. The contents of the other fields of the csw 
are not changed. 

1. An immediate operation was executed, and either 
no command chaining is specified, or chaining is sup- 
pressed because of unusual conditions detected during 
the operation. An operation is called immediate when 
the i/o device signals the channel-end condition imme- 
diately on receipt of the command code. The csw 



contains the channel-end bit and any other indications 
provided by the channel or the device. The busy bit 
is off. The i/o operation has been initiated, but no in- 
formation has been transferred to or from the storage 
area designated by the ccw. No interruption conditions 
are generated at the device or subchannel, and the 
subchannel is available for a new i/o operation. 

2. The i/o device contains a pending interruption 
condition due to device end or attention, the control 
unit contains a pending control unit end for the ad- 
dressed device, or, on the selector channel, the control 
unit contains for the addressed device a pending chan- 
nel end following the execution of halt i/o. The csw 
unit-status field contains the busy bit, identifies! the 
interruption condition, and may contain other bits pro- 
vided by the device or control unit. The interruption 
condition is cleared. The channel-status field indicates 
any error conditions detected by the channel and con- 
tains the PCI bit if specified in the first ccw. 

3. The i/o device or the control unit is executing a 
previously initiated operation, or the control unit has 
pending an interruption condition associated with a de- 
vice other than the one addressed. The csw unit-status 
field contains the busy bit or, if the control unit is 
busy, the busy and status-modifier bits. The channel- 
status field indicates any error conditions detected by 
the channel and contains the pci bit if specified in the 
first ccw. 

4. The i/o device or channel detected an eciuip- 
ment or programming error during execution of the 
instruction. The csw identifies the error condition. The 
channel-end and busy bits are off, unless the error was 
detected after the device was selected, and the device 
was found to be busy, in which case the busy bit, as 
well as any bits indicating pending interruption condi- 
tions, are on. The interruption conditions indicated in 
the csw have been cleared at the device. The i/o op- 
eration has not been initiated. No interruption condi- 
tions are generated at the i/o device or subchannel. 

On the multiplexor channel, start i/o causes the 
addressed device to be selected and the operation to 
be initiated only after the channel has serviced all out- 
standing requests for data transfer for previously ini- 
tiated operations. 

Resulting Condition Code: 

i/o operation initiated and channel proceed- 
ing with its execution 

1 csw stored 

2 Channel or subchannel busy 

3 Not operational 
Program Interruptions: 

Privileged operation. 
The condition code set by start i/o for all possi- 
ble states of the i/o system is shown graphically in 
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Figure 23. See the "States of the Input/Output Sys- 
tem" section of this manual for thorough definition of 
the A, I, W, and N states. 
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A = Available 

I = Interruption Pending 

W = Working 

N = Not Operational 

* = CSW Stored 

When A = 0, a regular I/O operation has been initiated and channel is proceeding 
with its execution. 

When A = 1*/ °ri immediate operation has been initiated and no command chaining 
is taking place. 

Note: Encircled condition codes pertain to conditions that can occur only on the 
multiplexor channel . 

Figure 23. Condition Code set by START I/O 

Programming Note 

When the channel detects a programming error dur- 
ing execution of start i/o and the addressed device 
contains an interruption condition, with the channel 
and subchannel in the available state, start i/o may or 
may not clear the interruption condition, depending 
on the type of error and the model. If the instruction 
has caused the device to be interrogated, as indicated 
by the presence of the busy bit in the csv7, the inter- 
ruption condition has been cleared, and the csw con- 
tains program or protection check, as well as the status 
from the device. 

Test I/O 

TIO Di(Bi) [51] 
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The state of the addressed channel, subchannel, and 
device is indicated by setting the condition code in 
the psw and, under certain conditions, by storing the 
csw. Pending interruption conditions may be cleared. 
The instruction test i/o is executed only when the 
CPU is in the supervisor state. 

Bit positions 16-31 of the sum formed by the addi- 
tion of the content of register Bi and the content of 
the Di field identify the channel, subchannel, and 
i/o device to which the instruction applies; 



When any of the following conditions occurs with 
the channel either available or in the interruption- 
pending state, TEST i/o causes the csw at location 64 
to be stored. The content of the entire csw pertains to 
the i/o device addressed by the instruction. 

1. The subchannel contains a pending interruption 
condition due to a terminated operation at the ad- 
dressed device. The csw identifies the interruption 
condition, and the interruption condition is cleared. 
The protection key, command address, and count 
fields contain the final values for the i/o operation, 
and the status may include other bits provided by 
the channel and the device. The interruption condi- 
tion in the subchannel is not cleared, and the csw is 
not stored if the interruption condition is associated 
with an operation on a device other than the one 
addressed. 

2. The subchannel is available and the i/o device 
contains a pending interruption condition due to de- 
vice end or attention, the control unit contains a pend- 
ing control unit end for the addressed device, or, on 
the selector channel, the control unit contains for the 
addressed device a pending channel end following the 
execution of halt i/o. The csw unit-status field identi- 
fies the interruption condition and may contain other 
bits provided by the device or control unit. The inter- 
ruption condition is cleared. The busy bit in the csw 
is oflF. The other fields of the csw contain zeros unless 
an equipment error is detected. 

3. The subchannel is available and the i/o device or 
the control unit is executing a previously initiated op- 
eration or the control unit has a pending interruption 
condition associated with a device other than the one 
addressed. The csw unit-status field contains the busy 
bit or, if the control unit is busy, the busy and status- 
modifier bits. Other fields of the csw contain zeros un- 
less an equipment error is detected. 

4. The subchannel is available and the i/o device or 
channel detected an equipment error during execution 
of the instruction or the addressed device is in the not- 
ready state and does not have any pending interrup- 
tion condition. The csw identifies the error conditions. 
If the device is not ready, unit check is indicated. No 
interruption conditions are generated at the i/o device 
or the subchannel. 

When TEST i/o is used to clear an interruption con- 
dition from the subchannel and the channel has not 
yet accepted the condition from the device, the in- 
struction causes the device to be selected and the 
interruption condition in the device to be cleared. Dur- 
ing certain i/o operations, some types of devices can- 
not provide their current status in response to test 
i/o. The tape control unit, for example, is in such a 
state when it has provided the channel-end condition 
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and is executing the backspace-file operation. When 
TEST i/o is issued to a control unit in such a state, the 
unit-status field of the csw contains the busy and 
status-modifier bits, with zeros in the other csw fields. 
The interruption condition in the device and in the 
subchannel is not cleared. 

On some types o£ devices, such as tlie 2702 Trans- 
mission Control, the device never provides its current 
status in response to test i/o, and an interruption 
condition can be cleared only by permitting an i/o 
interruption. When test i/o is issued to such a device, 
the unit-status field contains the status-modifier bit, 
with zeros in the other csw fields. The interruption 
condition in the device and in the subchannel, if any, 
is not cleared. 

However, at the time the channel assigns the high- 
est priority for interruptions to a condition associated 
with an operation at the subchannel, the channel ac- 
cepts the status from the device and clears the cor- 
responding condition at the device. When test i/o 
is addressed to a device for which the channel has 
already accepted the interruption condition, the de- 
vice is not selected, and the condition in the subchan- 
nel is cleared regardless of the type of device and its 
present state. The csw contains unit status and othei 
information associated with the interruption condi- 
tion. 

On the multiplexor channel, test i/o causes the ad- 
dressed device to be selected only after the channel 
has serviced all outstanding requests for data transfer 
for previously initiated operations. 

Resulting Condition Code: 

Available 

1 csw stored 

2 Channel or subchannel busy 

3 Not operational 
Program Interruptions: 

Privileged operation 
The condition code set by test i/o for all possible 
states of the i/o system is shown graphically in Figure 
24. See the "States of the Input/Output System" sec- 
tion of this manual for thorough definition of the A, I, 
W, and N states. 

Programming Notes 

Masking of channels provides the program a means of 
controlling the priority of i/o interruptions selectively 
by channels. The priority of devices attached on a 
channel is fixed and cannot be controlled by the pro- 
gram. The instruction test i/o permits the program to 
clear interruption conditions selectively by i/o device. 
When a csw is stored by test i/o, the interface- 
control-check and channel-control-check indications 
may be due to a condition already existing in the 



channel or due to a condition created by test i/o. 
Similarly, presence of the unit-check bit in thcs ab- 
sence of channel-end, control-unit-end or device-end 
bits may be due to a condition created by the preced- 
ing operation, the not-ready state, or an equipment er- 
ror detected during the execution of test i/o. The 
TEST i/o cannot be used to clear a pending interruption 
condition due to the pci flag while the subchannel is 
in the working state. 
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t: When the pending interruption condition is for the addressed device, t= 1* 
When the pending interruption condition is for another device, t = 2 

Note: Encircled condition codes pertain to conditions that can occur only on the 
multiplexor channel. 



Figure 24. Condition Code set by TEST I/O 
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Execution of the current i/o operation at the address- 
ed i/o device, subchannel, or channel is terminated. 
The subsequent state of the subchannel depends on 
the type of channel. The instruction halt i/o is exe- 
cuted only when the cpu is in the supervisor state. 

Bit positions 16-31 of the sum formed by the addi- 
tion of the contents of register Bi and the contents of 
the Di field identify the channel, and, when the chan- 
nel is not working, identify the subchannel and the 
i/o device to which the instruction applies. 

When the channel is either available or in the inter- 
ruption-pending state, with the subchannel either 
available or working, halt i/o causes the addressed 
device to be selected and to be signaled to terminate 
the current operation, if any. If the subchannel is 
available, its state is not affected. If, on the multiplexor 
channel, the subchannel is working, data transfer is 
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immediately terminated, but the subchannel remains 
in the working state until the device provides the next 
status byte, whereupon the subchannel is placed in the 
interruption-pending state. 

When HALT i/o is issued to a channel operating in 
the burst mode, data transfer for the burst operation is 
terminated, and the device performing the burst opera- 
tion is immediately disconnected from the channel. 
The subchannel and i/o device address in the instruc- 
tion, in this case, is ignored. 

The termination of a burst operation by halt i/o on 
the selector channel causes the channel and subchan- 
nel to be placed in the interruption-pending state. 
Generation of the interruption condition is not con- 
tingent on the receipt of a status byte from the device. 
When HALT i/o causes a burst operation on the multi- 
plexor channel to be terminated, the subchannel as- 
sociated with the burst operation remains in the work- 
ing state until the device provides channel end, where- 
upon the subchannel enters the interruption-pending 
state. 

On the multiplexor channel operating in the multi- 
plex mode, the device is selected and the instruction is 
executed only after the channel has serviced all out- 
standing requests for data transfer for previously initi- 
ated operations, including the operation to be halted. 
If the control unit does not accept the halt-i/o signal 
because it is in the not-operational or control-unit-busy 
state, the subchannel, if working, is set up to signal 
termination of device operation the next time the de- 
vice requests or offers a byte of data. If command 
chaining is indicated in the subchannel and the device 
presents status next, chaining is suppressed. 

When the addressed subchannel has a pending in- 
terruption condition, with the channel in the available 
or interruption-pending state, halt i/o does not cause 
any action. 

When any of the following conditions occur, halt 
i/o causes the status portion, bit positions 32-47, of 
the csw at location 64 to be replaced by a new set of 
status bits. The contents of the other fields of the csw 
are not changed. The csw stored by halt i/o pertains 
only to the execution of halt i/o and does not de- 
scribe under what conditions the i/o operation at the 
addressed subchannel is terminated. The extent of 
data transfer, and the conditions of termination of the 
operation at the subchannel, are provided in the csw 
associated with the interruption condition due to the 
termination. 

1. The addressed device has been selected and sig- 
naled to terminate the current operation. The csw 
contains zeros in the status field unless an equipment 
error is detected. 

2. The channel attempted to select the addressed 



device, but the control unit could not accept the halt- 
i/o signal because it is executing a previously initiated 
operation or has an interruption condition associated 
with a device other than the one addressed. The sig- 
nal to terminate the operation has not been trans- 
mitted to the device, and the subchannel, if in the 
working state, has been set up to signal termination 
the next time the device identifies itself. The csw unit- 
status field contains the busy and status-modifier bits. 
The channel-status field contains zeros unless an equip- 
ment error is detected. 

3. The channel detected an equipment malfunction 
during the execution of halt i/o. The status bits in 
the csw identify the error condition. The state of the 
channel and the progress of the i/o operation are un- 
predictable. 

When HALT i/o causes data transfer to be termi- 
nated, the control unit associated with the operation 
remains unavailable until the data-handling portion 
of the operation in the control unit is terminated. Ter- 
mination of data-transfer portion of the operation is 
signaled by generation of channel end, which may 
occur at the normal time for the operation, earlier, or 
later, depending on the operation and type of device. 
If the control unit is shared, all devices attached to 
the control unit appear in the working state until the 
channel-end condition is accepted by the cpu. The i/o 
device executing the terminated operation remains in 
the working state until termination of the inherent 
cycle of the operation, at which time device end is 
generated. If blocks of data at the device are defined, 
such as reading on magnetic tape, the recording medi- 
um is advanced to the beginning of the next block. 

When HALT i/o is issued at a time when the sub- 
channel is available and no burst operation is in prog- 
ress, the effect of the halt-i/o signal depends on the 
type of device and its state and is specified in the srl 
publication for the device. The halt-i/o signal has no 
effect on devices that are not in the working state or 
are executing an operation of a fixed duration, such 
as rewinding tape or positioning a disk access mecha- 
nism. If the device is executing a type of operation that 
is variable in duration, the device interprets the signal 
as one to terminate the operation. Pending attention 
or device-end conditions at the device are not reset. 

Resulting Condition Code: 

Interruption pending in subchannel 

1 csw stored 

2 Burst operation terminated 

3 Not operational 
Program Interruptions: 

Privileged operation 
The condition code set by halt i/o for all possible 
states of the i/o system is shown graphically in Fig- 
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ure 25. See the "States of the Input/Output System" 
section of this manual for thorough definition of the 
A, I, W, and N states. 
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A = Available 

I = Interruption Pending 

W = Working 

N = Not Operational 

* = CSW Stored 

Note; Encircled condition codes pertain to conditions that can occur only on the 
multiplexor channel . 



the available state is indicated. No device is selected, 
and, on the multiplexor channel, the subchannels are 
not interrogated. 

Resulting Condition Code: 

Channel available 

1 Interruption pending in channel 

2 Channel operating in burst mode 

3 Channel not operational 
Program Interruptions: 

Privileged operation 
The condition code set by test channel for all pos- 
sible states of the addressed channel is shown graphi- 
cally in Figure 26. See the "States of the Input/Output 
System" section of this manual for thorough definition 
of the A, I, W, and N states. 



Figure 25. Condition Code set by HALT I/O 

Programming Note 

The instruction halt i/o provides the program a 
means of terminating an i/o operation before all data 
specified in the operation have been transferred or be- 
fore the operation at the device has reached its normal 
ending point. It permits the program to immediately 
free the selector channel for an operation of higher 
priority. On the multiplexor channel, halt i/o pro- 
vides a means of controlling real-time operations and 
permits the program to terminate data transmission 
on a communication line. 
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The condition code in the psw is set to indicate the 
state of the addressed channel. The state of the chan- 
nel is not affected, and no action is caused. The in- 
struction TEST CHANNEL is cxccutcd Only w^hcn the cpu 
is in the supervisor state. 

Bit positions 16-23 of the sum formed by the addi- 
tion of the content of register Bi and the content of 
the Di field identify the channel to which the instruc- 
tion applies. Bit positions 24-31 of the address are 
ignored. 

The instruction test channel inspects only the state 
of the addressed channel. It tests whether the channel 
is operating in the burst mode, is aware of any out- 
standing interruption conditions from its devices, or 
is not operational. When the channel is operating in 
the burst mode and contains a pending interruption 
condition, the condition code is set as for operation in 
the burst mode. When none of these conditions exists. 
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A = Available 

I = Interruption Pending 

W = Working 

N = Not Operational 



Figure 26. Condition Code set by TEST CHANNEL 

Input/Output Instruction Exception Handling 

Before the channel is signaled to execute an i/o in- 
struction, the instruction is tested for validity by the 
CPU. Exceptional conditions detected at this time clause 
a program interruption. When the interruption occurs, 
the current psw is stored as the program old psw and 
is replaced by the program new psw. The interruption 
code in the old psw identifies the cause of the interrup- 
tion. 

The following exception may cause a program inter- 
ruption: 

Privileged Operation: An i/o instruction is encoun- 
tered when the cpu is in the problem state. The in- 
struction is suppressed before the channel has been 
signaled to execute it. The csw, the condition code in 
the PSW, and the state of the addressed subchannel 
and i/o device are not affected by the attempt to exe- 
cute an i/o instruction while in the problem state. 



Execution of Input/Output Operations 

The channel can execute six commands: write, read, 
read backward, control, sense, and transfer in channel. 
Each command except transfer in channel initiates 
a corresponding i/o operation. The term "i/o oper- 
ation" refers to the activity initiated by a commaEid in 
the i/o device and associated subchannel. The sub- 
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channel is involved with the execution of the opera- 
tion from the initiation of the command until the chan- 
nel-end signal is received or, in the case of command 
chaining, until the device-end signal is received. The 
operation in the device lasts until device end occurs. 

Blocking of Data 

Data recorded by an i/o device may be divided into 
blocks. A block of data is defined for each type of i/o 
device as the amount of information recorded in the 
interval between adjacent starting and stopping points 
of the device. The length of a block depends on the 
document; for example, a block can be a card, a line 
of printing, or the information recorded between two 
consecutive gaps on magnetic tape. 

The maximum amount of information that can be 
transferred in one i/o operation is one block. An i/o 
operation is terminated when the associated storage 
area is exhausted or the end of the block is reached, 
whichever occurs first. For some operations, such as 
writing on a magnetic tape unit or on an inquiry sta- 
tion, blocks are not defined, and the amount of in- 
formation transferred is controlled only by the pro- 
gram. 

Channel Address Word 

The channel address word (caw) specifies the storage 
protection key and the address of the first ccw associ- 
ated with START i/o. It is assigned location 72. The 
channel refers to the caw only during the execution 
of START i/o. The pertinent information thereafter is 
stored in the subchannel, and the program is free to 
change the content of the caw. Fetching of the caw 
by the channel does not affect the contents of location 
72. 

The CAW has the following format: 



Key 



Command Address 



The fields in the caw are allocated for the follow- 
ing purposes: 

Protection Key: Bits 0-3 form the protection key for 
all commands associated with start i/o. This key is 
matched with a key in storage whenever reference is 
made to main storage. 

Command Address: Bits 8-31 designate the location 
of the first ccw in main storage. 

Bit positions 4-7 of the caw must contain zeros. 
When the protection feature is not implemented, the 
protection key must b€! zero. The three low-order bits 
of the command addr(3ss must be zero to specify the 
ccw on integral boundaries for double words. If any 
of these restrictions is violated or if the command ad- 
dress specifies a location protected for fetching or 



outside the main storage of the particular installation, 
START i/o causes the status portion of the csw to be 
stored with the protection-check or program-check bit 
on. In this event, the i/o operation is not initiated. 

Programming Note 

Bit positions 4-7 of the caw, which presently must con- 
tain zeros, may in the future be assigned for the 
control of new functions. It is therefore recommended 
that these bit positions not be set to one for the pur- 
pose of obtaining an intentional program-check indi- 
cation. 

Channel Command Word 

The channel command word (ccw) specifies the com- 
mand to be executed and, for commands initiating 
i/o operations, it designates the storage area associ- 
ated with the operation and the action to be taken 
whenever transfer to or from the area is completed. 
The ccw's can be located anywhere in main storage, 
and more than one can be associated with a start 
i/o. The channel refers to a ccw in main storage only 
once, whereupon the pertinent information is stored 
in the channel. 

The first ccw is fetched during the execution of 
START i/o. Each additional ccw in the sequence is ob- 
tained when the operation has progressed to the point 
where the additional ccw is needed. Fetching of the 
ccw's by the channel does not affect the contents of 
the location in main storage. 

The ccw has the following format: 



Command 
Code 


Data Address 







7 8 


31 


Flags 


000 


mm. 


Count 



36 37 39 40 



The fields in the ccw are allocated for the following 
purposes: 

Command Code: Bits 0-7 specify the operation to 
be performed. 

Data Address: Bits 8-31 specify the location of an 
eight-bit byte in main storage. It is the first location 
referred to in the area designated by the ccw. 

Chain-Data (CD) Flag: Bit 32, when one, specifies 
chaining of data. It causes the storage area designated 
by the next ccw to be used with the current operation. 

Chain-Command (CC) Flag: Bit 33, when one, and 
when the cd flag is zero, specifies chaining of com- 
mands. It causes the operation specified by the com- 
mand code in the next ccw to be initiated on normal 
completion of the current operation. 

Suppress-Length-Indication (SLI) Flag: Bit 34 con- 
trols whether an incorrect length condition is to be 
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indicated to the program. When this bit is one and the 
CD flag is zero in the last ccw used, the incorrect length 
indication is suppressed. When both the cc and sli 
flags are one, command chaining takes place regardless 
of the presence of an incorrect length condition. 

Skip (SKIP) Flag: Bit 35, when one, specifies sup- 
pression of transfer of information to storage during a 
read, read backward, or sense operation.. 

Program-Controlled-Interruption (PCI) Flag: Bit 36, 
when one, causes the channel to generate an inter- 
ruption condition when the ccw takes control of the 
channel. When bit 36 is zero, normal operation takes 
place. 

Count: Bits 48-63 specify the number of eight-bit 
byte locations in the storage area designated by the 
ccw. 

Bit positions 37-39 of every ccw other than one spe- 
cifying transfer in channel must contain zeros. Viola- 
tion of this restriction generates the program-check 
condition. When the first ccw designated by the caw 
does not contain the required zeros, the i/o operation 
is not initiated, and the status portion of the csw with 
the program-check indication is stored during execu- 
tion of START i/o. Detection of this condition during 
data chaining causes the i/o device to be signaled to 
terminate the operation. When the absence of these 
zeros is detected during command chaining, the new 
operation is not initiated, and an interruption condition 
is generated. 

The content of bit positions 40-47 of the ccw is 
ignored. 

Programming Note 

Bit positions 37-39, of the ccw, which presently must 
contain zeros, may in the future be assigned for the 
control of new functions. It is therefore recommended 
that these bit positions not be set to one for the pur- 
pose of obtaining a program-check indication. 

Command Code 

The command code, bit positions 0-7 of the ccw, speci- 
fies to the channel and the i/o device the operation to 
be performed. 

The two low-order bits or, when these bits are 
00, the four low-order bits of the command code iden- 
tify the operation to the channel. The channel dis- 
tinguishes among the following four operations: 

Output forward (write, control) 

Input forward (read, sense) 

Input backward ( read backward ) 

Branching ( transfer in channel ) 

The channel ignores the high-order bits of the com- 
mand code. 

Commands that initiate i/o operations (write, read, 
read backward, control, and sense) cause all eight bits 



of the command code to be transferred to the i/o de- 
vice. In these command codes, the high-order bit po- 
sitions contain modifier bits. The modifier bits specify 
to the device how the command is to be executed. 
They may cause, for example, the device to compare 
data received during a write operation with data pre- 
viously recorded, and they may specify such con- 
ditions as recording density and parity. For the control 
command, the modifier bits may contain the order 
code specifying the control function to be performed. 
The meaning of the modifier bits depends on the type 
of i/o device and is specified in the srl publicjation 
for the device. 

The command code assignment is listed in the fol- 
lowing table. The symbol x indicates that the bit po- 
sition is ignored; m identifies a modifier bit. 



CODE 


COMMAND 


X X X X 00 


Invalid 


MMMM 1 00 


Sense 


X X X X 1 00 


Transfer in channel 


MMMM 1 1 00 


Read backward 


MMMM MMOI 


Write 


MMMM MM 10 


Read 


MMMM MMll 


Control 



Whenever the channel detects an invalid command 
code during the initiation of a command, the pro- 
gram-check condition is generated. When the first ccw 
designated by the caw contains an invalid command 
code, the status portion of the csw with the program- 
check indication is stored daring execution of start 
i/o. When the invalid code is detected during com- 
mand chaining, the new operation is not initiated, and 
an interruption condition is generated. The command 
code is ignored during data chaining, unless it speci- 
fies transfer in channel. 

Defmition of Storage Area 

The main-storage area associated with an i/o oper- 
ation is defined by ccw's. A ccw defines an area by 
specifying the address of the first eight-bit byte to be 
transferred and the number of consecutive eight-bit 
bytes contained in the area. The address of the first 
byte appears in the data-address field of the ccw, The 
number of bytes contained in the storage area is spe- 
cified in the count field. 

In write, read, control, and sense operations storage 
locations are used in ascending order of addresses. As 
information is transferred to or from main storage, the 
content of the address field is incremented, and the 
content of the count field is decremented. The read- 
backward operation causes data to be placed in stor- 
age in a descending order of addresses, and both the 
count and the address are decremented. When the 
count in any operation reaches zero, the storage area 
defined by the ccw is exhausted. 
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Any main-storage location provided in the system 
can be used to transfer data to or from an i/o device, 
provided that the location is not protected for the type 
of reference. Similarly, the ccw's can be specified in 
any part of available main storage, provided the loca- 
tion is not protected for a fetch-type reference. When 
the channel attempts to refer to a protected location, 
the protection-check condition is generated, and the 
device is signaled to terminate the operation. 

In the event the channel refers to a location not pro- 
vided in the system, the program-check condition is 
generated. The method of indicating the error condi- 
tion and terminating the i/o operation upon detection 
of an invalid address depends on whether or not the 
address exceeds the addressing capacity of the model. 
The term "addressing capacity" refers to the model's 
facilities for addressing main storage. Most models 
have facilities for addressing up to 16,777,216 bytes 
regardless of the storage provided in the particular 
installation. In some models, however, the addressing 
facilities in the channel are restricted to main storage 
of less than 16,777,216 bytes. When the first ccw des- 
ignated by the caw is at a nonexistent location or the 
first ccw contains a data address exceeding the ad- 
dressing capacity of the model, the i/o operation is not 
initiated and the status portion of the csw with the pro- 
gram-check indication is stored during the execution 
of START i/o. Invalid data addresses within the ad- 
dressing capacity of the model, as well as any invalid 
ccw addresses detected on chaining, are indicated 
to the program with the interruption conditions at the 
termination of the operation or chain of operations. 

During an output operation, the channel may fetch 
data from the main storage prior to the time the i/o de- 
vice requests the data. As many as 16 bytes may be 
prefetched and buffered. Similarly, on data chaining 
during an output operation, the channel may fetch the 
new ccw when as many as 16 bytes remain to be 
transferred under the control of the current ccw. 
When the i/o operation uses data and ccw's from lo- 
ations near the end of the available storage, such pre- 
fetching may cause the channel to refer to locations 
that do not exist. Invalid addresses detected during 
prefetching of data or ccw's do not affect the execu- 
tion of the operation and do not cause error indica- 
tions until the i/o operation actually attempts to use 
the information. If the operation is terminated by the 
i/o device or by halt i/o before the invalid informa- 
tion is needed, the condition is not brought to the 
attention of the program. 

Storage addresses do not wrap around to location 
unless the system has the maximum addressable stor- 
age (16,777,216 bytes). When the maximum address- 
able storage is provided, location follows location 



16,777,215 and, on reading backward, location 
16,777,215 follows location 0. 

The count field in the ccw can specify any number 
of bytes up to 65,535. Except for a ccw specifying 
transfer in channel, the count field may not contain the 
value zero. Whenever the count field in the ccw initi- 
ally contains a zero, the program-check condition is 
generated. When this occurs in the first ccw desig- 
nated by the caw, the operation is not initiated, and 
the status portion of the csw with the program-check 
indication is stored during execution of start i/o. 
When a count of zero is detected during data chain- 
ing, the i/o device is signaled to terminate the opera- 
tion. Detection of a count of zero during command 
chaining suppresses initiation of the new operation and 
generates an interruption condition. 

Chaining 

When the channel has performed the transfer of in- 
formation specified by a ccw, it can continue the ac- 
tivity initiated by start i/o by fetching a new ccw. 
Such fetching of a new ccw is called chaining, and 
the ccw's belonging to such a sequence are said to 
be chained. 

Chaining takes place only between ccw's located 
in successive double-word locations in storage. It pro- 
ceeds in an ascending order of addresses; that is, the 
address of the new ccw is obtained by adding eight 
to the address of the current ccw. Two chains of 
ccw's located in noncontiguous storage areas can be 
coupled for chaining purposes by a transfer in chan- 
nel command. All ccw's in a chain apply to the i/o 
device specified in the original start i/o. 

Two types of chaining are provided: chaining of 
data and chaining of commands. Chaining is con- 
trolled by the chain-data (cd) and chain-command 
(cc) flags in conjunction with the suppress-length 
indication (sli) flag in the ccw. These flags specify 
the action to be taken by the channel upon the ex- 
haustion of the current ccw and upon receipt of end- 
ing status from the device, as shown in Figure 27. 

The specification of chaining is effectively propa- 
gated through a transfer in channel command. When 
in the process of chaining a transfer-in-channel com- 
mand is fetched, the ccw designated by the transfer 
in channel is used for the type of chaining specified 
in the ccw preceding the transfer in channel. 

The CD and cc flags are ignored in the transfer-in- 
channel command. 

Data Chaining 

During data chaining, the new ccw fetched by the 
channel defines a new storage area for the original i/o 
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operation. Execution of the operation at the i/o device 
is not affected. Data chaining occurs only when all data 
designated by the current ccw have been transferred 
to or from the device and causes the operation to con- 
tinue, using the storage area designated by the new 
ccw. The content of the command-code field of the 
new ccw is ignored, unless it specifies transfer in 
channel. 

Data chaining is considered to occur immediately 
after the last byte of data designated by the current 
ccw has been transferred to or from the device. When 
the last byte has been placed in main storage or ac- 
cepted by the device, the new ccw takes over the con- 
trol of the operation and replaces the pertinent in- 
formation in the subchannel. If the device sends chan- 
nel end after exhausting the count of the current ccw 
but before transferring any data to or from the storage 
area designated by the new ccw, the csw associated 
with the termination pertains to the new ccw. 

If programming errors are detected in the new ccw 
or during its fetching, an error indication is gener- 
ated, and the device is signaled to terminate the 
operation when it attempts to transfer data designated 
by the new ccw. If the device signals the channel-end 
condition before transferring any data designated by 
the new ccw, program check or protection check is 
indicated in the csw associated with the termination. 
Unless the address of the new ccw is invalid, the loca- 



tion is protected for fetching, or programming errors 
are detected in an intervening transfer-in-channel com- 
mand, the content of the csw pertains to the new ccw. 
A data address referring to a nonexistent or protected 
area causes an error indication only after the i/o de- 
vice has attempted to transfer data to or from the in- 
valid location, but an address exceeding the addressing 
capacity of the model is detected immediately upon 
fetching the ccw. 

Data chaining during an input operation causes the 
new ccw to be fetched when all data designated by 
the current ccw have been placed in main storage. On 
an output operation, the channel may fetch the new 
ccw from main storage ahead of the time data chain- 
ing occurs. The earliest such prefetching may occur 
is when 16 bytes still remain to be transferred under 
the control of the current ccw. Any programming 
errors in the prefetched ccw, however, do not affect 
the execution of the operation until all data desig- 
nated by the current ccw have been transferred to the 
i/o device. If the device terminates the operation be- 
fore all data designated by the current ccw have been 
transferred, the conditions associated with the pre- 
fetched ccw are not indicated to the program. 

Only one ccw describing a data area may be pre- 
fetched and buffered in the channel. If the prefetched 
ccw specifies transfer in channel, only one more ccw 
is fetched before the exhaustion of the current ccw. 



Flags in 
Currenf CCW 



CD CC SLI 







1 

1 



Action in Channel upon Exhaustion of Count or Receipt of Channel End 



IMMEDIATE OPERATION 



End, - 
End, - 

Chain Command 
Chain Command 

End, - 

End, - 

End, - 

End, - 



REGULAR OPERATION 



Count Exhausted, End of 
B lock at Device not Reached 

Stop, IL 
Stop, - 
Stop, IL 
Chain Command 

Chain Data 
Chain Data 
Chain Data 
Chain Data 



Count Exhausted and Channel 
End from Device 

End, - 
End, - 

Chain Command 
Chain Command 



Count not Exhausted and 
Channel End from Device 



End, 


IL 


End, 


- 


End, 


IL 


Chai 


n Command 


End, 


IL 


End, 


IL 


End, 


IL 


End, 


IL 



End The operation is terminated. If the operation is immediate and has been specified by the first CCW associated with a 

START I/O, a condition code of 1 is set, and the status portion of the CSW is stored as part of the execution of the 
START I/O. In all other cases an interruption condition is generated in the subchannel. 

Stop The device is signaled to terminate data transfer, but the subchannel remains in the working state until channel end 

is received; at this time an interruption condition is generated in the subchannel. 

IL Incorrect length is indicated with the interruption condition. 

Chain Command The channel performs command chaining upon receipt of device end. 

Chain Data The channel immediately fetches a new CCW for the same operation. 

The situation where the count is zero but data chaining is indicated at the time the device provides channel end 
cannot validly occur. When data chaining is indicated, the channel fetches the new CCW after transferring the last 
byte of data designated by the current CCW but before the device provides the next request for data or status transfer. 
As a result, the channel recognizes the channel end from the device only after it has fetched the new CCW, which 
cannot contain a count of zero unless a programming error has been made. 

Figure 27. Effect of CD, GC, and SLI Flags on an I/O Operation 
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Programming Note 

Data chaining may be used to rearrange information 
as it is transferred between main storage and an i/o 
device. Data chaining permits blocks of information to 
be transferred to or from noncontiguous areas of stor- 
age, and, when used in conjunction with the skipping 
function, data chaining enables the program to place 
in main storage selected portions of a block of data. 

When, during an input operation, the program speci- 
fies data chaining to a location into which data have 
been placed under the control of the current ccw, the 
channel fetches the new content of the location, even 
if the location contains the last byte transferred under 
the control of the current ccw. When a channel pro- 
gram data-chains to a ccw placed in storage by the 
ccw specifying data chaining, the input block is said 
to be self-describing. A self-describing block contains 
one or more ccw's that specify storage locations and 
counts for subsequent data in the same input block. 

When data chaining is used during a read-backward 
operation, the channel places data in storage in a de- 
scending sequence, but fetches ccw's in an ascending 
sequence. Therefore, if a magnetic tape block is to be 
written so that it can be read in either the forward or 
backward direction as a self-describing block, the ccw 
must be written at both the beginning and the end of 
the block. If more than one ccw is to be used, the 
order of the ccw's must be reversed at the end of the 
block because the storage areas associated with the 
ccw's are used in reverse sequence. 

Use of self-describing blocks, however, is equivalent 
to use of unchecked data. An i/o data transfer mal- 
function that affects validity of a block of information 
is signaled only at the completion of data transfer. The 
error condition normally does not prematurely termin- 
ate or otherwise affect the execution of the operation. 
Thus, there is no assurance that a ccw read as data is 
valid until the operation is completed. If the ccw thus 
read is in error, use of the ccw in the current opera- 
tion may cause subsequent data to be placed in wrong 
locations in main storage with resultant destruction of 
its contents, subject to the control of the protection 
system. 

Command Chaining 

During command chaining, the new ccw fetched by 
the channel specifies a new i/o operation. The chan- 
nel fetches the new c:cw and initiates the new oper- 
ation upon the receipt of the device-end signal for the 
current operation. When command chaining takes 
place, the completion of the current operation does 
not cause an i/o interruption, and the count indicat- 
ing the amount of data transferred during the current 
operation is not made available to the program. For 



operations involving data transfer, the new command 
always applies to the next block of data at the device. 

Command chaining takes place and the new oper- 
ation is initiated only if no unusual conditions have 
been detected in the current operation. In particular, 
the channel initiates a new i/o operation by com- 
mand chaining upon receipt of a status byte contain- 
ing only the following bit combinations: device end, 
device end and status modifier, device end and chan- 
nel end, device end and channel end and status modi- 
fier. In the former two cases a channel end must have 
been signaled before device end, with all other status 
bits off. If a condition such as attention, unit check, 
unit exception, incorrect length, program check, or 
protection check has occurred, the sequence of opera- 
tions is terminated, and the status associated with the 
current operation causes an interruption condition to 
be generated. The new ccw in this case is not fetched. 
The incorrect-length condition does not suppress com- 
mand chaining if the current ccw has the sli flag on. 

An exception to sequential chaining of ccw's occurs 
when the i/o device presents the status-modifier con- 
dition with the device-end signal. When command 
chaining is specified and no unusual conditions have 
been detected, the combination of status-modifier and 
device-end bits causes the channel to fetch and chain 
to the ccw whose main-storage address is 16 higher 
than that of the current ccw. 

When both command and data chaining are used, 
the first ccw associated with the operation specifies 
the operation to be executed, and the last ccw indi- 
cates whether another operation follows. 

Programming Note 

Command chaining makes it possible for the program 
to initiate transfer of multiple blocks of data by means 
of a single start i/o. It also permits a subchannel to 
be set up for execution of auxiliary functions, such as 
positioning the disk access mechanism, and for data 
transfer operations without interference by the pro- 
gram at the end of each operation. Command chain- 
ing, in conjunction with the status-modifier condition, 
permits the channel to modify the normal sequence of 
operations in response to signals provided by the i/o 
device. 

Skipping 

Skipping is the suppression of main-storage references 
during an i/o operation. It is defined only for read, 
read backward, and sense operations and is controlled 
by the skip flag, which can be specified individually 
for each ccw. When the skip flag is one, skipping oc- 
curs; when zero, normal operation takes place. The 
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setting of the skip flag is ignored in all other oper- 
ations. 

Skipping affects only the handling of information 
by the channel. The operation at the i/o device pro- 
ceeds normally, and information is transferred to the 
channel. The channel keeps updating the count but 
does not place the information in main storage. If the 
chain-command or chain-data flag is one, a new ccw 
is obtained when the count reaches zero. In the case 
of data chaining, normal operation is resumed if the 
skip flag in the new ccw is zero. 

No checking for invalid or protected data addresses 
takes place during skipping, except that the initial 
data address in the ccw cannot exceed the addressing 
capacity of the model. 

Programming Note 

Skipping, when combined with data chaining, permits 
the program to place in main storage selected portions 
of a block of information from an i/o device. 

Program-Controlled Interruption 

The program-controlled interruption (pci) function 
permits the program to cause an i/o interruption dur- 
ing execution of an i/o operation. The function is con- 
trolled by the pci flag in the ccw. The flag can be on 
either in the first ccw specified by start i/o or in a 
ccw fetched during chaining. Neither the pci flag nor 
the associated interruption affects the execution of the 
current operation. 

Whenever the pci flag in the ccw is on, the channel 
attempts to interrupt the program. When the first ccw 
associated with an operation contains the pci flag, 
either initially or upon command chaining, the inter- 
ruption may occur as early as immediately upon the 
initiation of the operation. The pci flag in a ccw 
fetched on data chaining causes the interruption to 
occur after all data designated by the preceding ccw 
have been transferred. The time of the interruption, 
however, depends on the model and the current ac- 
tivity in the system and may be delayed even if the 
channel is not masked. No predictable relation exists 
between the time the interruption due to the pci flag 
occurs and the progress of data transfer to or from the 
area designated by the ccw, but the fields within the 
csw pertain to the same instant of time. 

If chaining occurs before the interruption due to 
the PCI flag has taken place, the pci condition is car- 
ried over to the new ccw. This carryover occurs both 
on data and command chaining and, in either case, 
the condition is propagated through the transfer-in- 
channel command. The pci conditions are not stacked; 
that is, if another ccw is fetched with a pci flag before 
the interruption due to the pci flag of the previous 



ccw has occurred, only one interruption takes place. 

A csw containing the pci bit may be stored by an 
interruption while the operation is still proceeding or 
by an interruption or test i/o upon the termination 
of the operation. It cannot be stored by test i/6 
while the subchannel is in the working state. 

When the csw is stored by an interruption before 
the operation or chain of operations has been termi- 
nated, the command address is eight higher than the 
address of the current ccw, and the count is unpre- 
dictable. All unit-status bits in the csw are zero. If the 
channel has detected any unusual conditions, such as 
channel data check, program check, or protection 
check by the time the interruption occurs, the ccirre- 
sponding channel-status bit is on, although the con- 
dition in the subchannel is not reset and is indicated 
again upon the termination of the operation. 

Presence of any unit-status bit in the csw indicates 
that the operation or chain of operations has been 
terminated. The csw in this case has its regular for- 
mat with the pci bit added. 

However, when the interruption condition due to 
the PCI flag has been delayed until the operation at 
the subchannel has been terminated, two interrup- 
tions from the subchannel may still take place, with 
the first interruption indicating and clearing the pci 
condition alone, and the second providing the csw 
associated with the ending status. Whether one or 
two interruptions occur depends on the model, and 
on whether the pci condition has been assigned the 
highest priority for interruption at the time of termi- 
nation. The TEST i/o addressed to the device associated 
with an interruption condition in the subchannel clears 
the PCI condition as well as the one associated vdth 
the termination. 

The setting of the pci flag is inspected in every ccw 
except those specifying transfer in channel. In a c:cw 
specifying transfer in channel, the setting of the flag 
is ignored. The pci flag is ignored also during initial 
program loading. 

Programming Note 

Since no unit-status bits are placed in the csw associ- 
ated with the termination of an operation on the se- 
lector channel by halt i/o, the presence of a unit- 
status bit with the pci bit is not a necessary condition 
for the operation to be terminated. When the selector 
channel contains the pci bit at the time the operation 
is terminated by halt i/o, the csw associated with 
the termination is indistinguishable from the csw pro- 
vided by an interruption during execution of the op- 
eration. 

Program-controlled interruption provides a means 
of alerting the program of the progress of chaining 
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during an i/o operation. It permits programmed dy- 
namic main-storage allocation. 

Commands 

The following table lists the command codes for the 
six commands and indicates which flags are defined 
for each command. The flags are ignored for all com- 
mands for which they are not defined. 



NAME 

Write 

Read 

Read backward 

Control 

Sense 

Transfer in channel 

NOTES 

CD 

CC 

SLI 

SKIP 

PCI 

M 

X 



CODE 
MMMM MMOI 
MMMM MMIO 
MMMM 1 1 00 
MMMM MMll 
MMMM 1 00 
X X X X 1 00 



FLAG 

CD CC SLI PCI 

CD CC SLI SKIP PCI 
CD CC SLI SKIP PCI 
CD CC SLI PCI 

CD CC SLI SKIP PCI 



Chain data 

Chain command 

Suppress length indication 

Skip 

Program-controlled interruption 

Modifier bit 

Ignored 

All flags have individual significance, except that 
the CC and sli flags are ignored when the cd flag is on. 
The SLI flag is ignored on immediate operations, in 
which case the incorrect-length indication is sup- 
pressed regardless of the setting of the flag. The pci 
flag is ignored during initial program loading. 

Each command is described below with an illustra- 
tion of its ccw format. 

Programming Note 

A malfunction that ajffects the validity of data trans- 
ferred in an i/o operation is signaled at the end of the 
operation by means of unit check or channel data check, 
depending on whether the device (control unit) or 
the channel detected the error. In order to make use 
of the checking facilities provided in the system, data 
read in an input operation should not be used until 
the end of the operation has been reached and the 
validity of the data has been checked. Similarly, on 
writing, the copy of data in main storage should not 
be destroyed until the program has verified that no 
malfunction affecting the transfer and recording of 
data was detected. 

IVrJfe 



to the i/o device. Data in storage are fetched in an 
ascending order of addresses, starting with the ad- 
dress specified in the ccw. 

A ccw used in a write operation is inspected for the 
CD, cc, SLI, and the pci flags. The setting of the skip 
flag is ignored. Bit positions 0-5 of the ccw contain 
modifier bits. 

Programming Note 

When writing on devices for which block length is 
not defined, such as a magnetic tape unit or an inquiry 
station, the amount of data written is controlled only 
by the count in the ccw. Every operation terminated 
under count control causes the incorrect-length indica- 
tion, unless the indication is suppressed by the sli flag. 

Read 



MMMMMMIO 


Data Address 



yoGO: 



Count 



A read operation is initiated at the i/o device, and the 
subchannel is set up to transfer data from the device 
to main storage. For devices such as magnetic tape 
units, disk storage, and card equipment, the bytes of 
data within a block are provided in the same sequence 
as written by means of a write command. Data in 
storage are placed in an ascending order of addresses, 
starting with the address specified in the ccw. 

A ccw used in a read operation is inspected for 
every one of the five flags — cd, cc, sli, skip, and pci. 
Bit positions 0-5 of the ccw contain modifier bits. 

Read Backward 



MMMMl 100 


Data Address 


7 8 




31 


u 


U 
U 




a. 


U 

a. 


000 




^ 


Count 



MMMMMM 01 


Data Address 



m 



39 40 



Count 



A write operation is initiated at the i/o device, and the 
subchannel is set up to transfer data from main storage 



A read-backward operation is initiated at the i/o de- 
vice, and the subchannel is set up to transfer data 
from the device to main storage. On magnetic tape 
units, read backward causes reading to be performed 
with the tape moving backwards. The bytes of data 
within a block are sent to the channel in a sequence 
opposite to that on writing. The channel places the 
bytes in storage in a descending order of address, start- 
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ing with the address specified in the ccw. The bits 
within an eight-bit byte are in the same order as sent 
to the device on writing. 

A ccw used in a read-backward operation is in- 
spected for every one of the five flags — cd, cc, sli, 
SKIP, and PCI. Bit positions 0-3 of the ccw contain 
modifier bits. 

Control 



MMMMMM 1 1 


Data Address 



M 



u 



000; 



Count 



A control operation is initiated at the i/o device, and 
the subchannel is set up to transfer data from main 
storage to the device. The device interprets the data 
as control information. The control information, if 
any, is fetched from storage in an ascending order of 
addresses, starting with the address specified in the 
ccw. A control command is used to initiate at the i/o 
device an operation not involving transfer of data — 
such as backspacing or rewinding magnetic tape or 
positioning a disk access mechanism. 

For most control functions, the entire operation is 
specified by the modifier bits in the command code, 
and the function is performed over the i/o interface 
as an immediate operation (see "Immediate Opera- 
tions"). If the command code does not specify the 
entire control function, the data-address field of the 
ccw designates the location containing the required 
additional information. This control information may 
include an order code further specifying the operation 
to be performed or an address, such as the disk address 
for the seek function, and is transferred in response to 
requests by the device. 

A control command code containing zeros for the 
six modifier bits is defined as no operation. The no- 
operation order causes the addressed device to respond 
with channel end and device end without causing any 
action at the device. The order can be executed as an 
immediate operation, or the device can delay the 
status until after the initiation sequence is completed. 
Other operations that can be initiated by means of the 
control command depend on the type of i/o device. 
These operations and their codes are specified in the 
SRL publication for the device. 

A ccw used in a control operation is inspected for 
the CD, cc, SLi, and the pci flags. The setting of the 
skip flag is ignored. Bit positions 0-5 of the ccw con- 
tain modifier bits. 



Programming Note 

Since a ccw with a count of zero is invalid, the pro- 
gram cannot use the ccw count field to specify that 
no data be transferred to the i/o device. Any opera- 
tion terminated before data have been transferred 
causes the incorrect-length indication, provided the 
operation is not immediate and has not been rejected 
during the initiation sequence. The incorrect-length 
indication is suppressed when the sli flag is on. 

$en«e 



MMMMOIOO 


Data Address 



^5;000; 



Count 



A sense operation is initiated at the i/o device, and 
the subchannel is set up to transfer data from the de- 
vice to main storage. The data are placed in storage 
in an ascending order of addresses, starting with the 
address specified in the ccw. 

Data transferred during a sense operation provide 
information concerning both unusual conditions de- 
tected in the last operation and the status of the de- 
vice. The status information provided by the sense 
command is more detailed than that supplied by the 
unit-status byte and may describe reasons for the unit- 
check indication. It may also indicate, for example, if 
the device is in the not-ready state, if the tape unit is 
in the file-protected state, or if magnetic tape is posi- 
tioned beyond the end-of-tape mark. 

For most devices, the first six bits of the sense data 
describe conditions detected during the last opera- 
tion. These bits are common to all devices having this 
type of information and are designated as follows: 



3IT 


DESIGNATION 




1 

2 
3 
4 
5 


Command reject 
Intervention required 
Bus-out check 
Equipment check 
Data check 
Overrun 



The following is the meaning of the first six bits: 
Command Reject: The device has detected a pro- 
gramming error. A command has been received which 
the device is not designed to execute, such as read 
backward issued to a direct-access storage device, or 
which the device cannot execute because of its present 
state, such as write issued to a file-protected tape unit. 
Command reject is also indicated when the program 
issues an invalid sequence of commands, such as write 
to a direct-access storage device without previously 
designating the data block. 
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Intervention Required: The last operation could not 
be executed because of a condition requiring some 
type of intervention at the device. This bit indicates 
conditions such as an empty hopper in a card punch 
or the printer being out of paper. It is also turned on 
when the addressed device is in the not-ready state, is 
in test mode, or is not provided on the control unit. 

Bus-Out Check: The device or the control unit has 
received a data byte or a command code with an in- 
valid parity over the i/o interface. During writing, 
bus-out check indicates that incorrect data have been 
recorded at the device, but the condition does not 
cause the operation to be terminated prematurely. 
Parity errors on command codes and control informa- 
tion cause the operation to be immediately terminated 
and suppresses checking for command-reject and in- 
tervention-required conditions. 

Equipment Check: During the last operation, the 
device or the control unit has detected equipment mal- 
functioning, such as an invalid card hole count or 
printer buffer parity error. 

Data Check: The device or the control unit has de- 
tected a data error other than those included in bus- 
out check. Data check identifies errors associated with 
the recording medium and includes conditions such as 
reading an invalid card code or detecting invalid par- 
ity on data recorded on magnetic tape. 

On an input operation, data check indicates that 
incorrect data may have been placed in main storage. 
The control unit forces correct parity on data sent to 
the channel. On writing, this condition indicates that 
incorrect data may have been recorded at the device. 
Unless the operation is of a type where the error pre- 
cludes meaningful continuation, data errors on read- 
ing and writing do not cause the operation to be 
terminated prematurely. 

Overrun: The channel has failed to respond on time 
to a request for service from the device. Overrun can 
occur when data are transferred to or from a non- 
buflFered control unit operating with a synchronous 
medium, and the total activity initiated by the program 
exceeds the capability of the channel. When the chan- 
nel fails to accept a byte on an input operation, the 
following data in main storage are shifted to fill the 
gap. On an output operation, overrun indicates that 
data recorded at the device may be invalid. The over- 
run bit is also turned on when the device receives the 
new command too late during command chaining. 

All information significant to the use of the device 
normally is provided in the first two bytes. Any bit 
positions following those used for programming in- 
formation contain diagnostic information, which may 
extend to as many bytes as needed. The amount and 



the meaning of the status information are peculiar to 
the type of i/o device and are specified in the srl 
publication for the device. 

The basic sense command has zero modifier bits. 
This command initiates a sense operation on all de- 
vices and cannot cause the command-reject, interven- 
tion-required, data-check, or overrun bits to be turned 
on. If the control unit detects an equipment malfunc- 
tion, or invalid parity of the sense command code, the 
equipment-check or bus-out-check bits are turned on, 
and unit check is sent with channel end. 

Devices that can provide special diagnostic sense in- 
formation or can be instructed to perform other special 
functions by use of the sense command, may define 
modifier bits for the control of these functions. The 
special sense operations may be initiated by a unique 
combination of modifier bits, or a group of codes may 
specify the same function. Any remaining sense com- 
mand codes may be considered invalid, thus causing 
the unit-check indication, or may cause the same 
action as the basic sense command, depending upon 
the type of device. 

The sense information pertaining to the last i/o op- 
eration is reset the next time the program causes the 
associated control unit to be selected, unless the selec- 
tion is due to the execution of test i/o, or halt i/o, 
or unless the basic sense operation, or a no-operation 
order is initiated at the control unit. 

A ccw used in a sense operation is inspected for 
every one of the five flags — cd, cc, sli, skip, and 
PCI. Bit positions 0-3 of the ccw contain modifier bits. 

Transfer In Channel 



1000 



ccw Address 



34 78 




^ 



The next ccw is fetched from the location designated 
by the data-address field of the ccw specifying trans- 
fer in channel. The transfer-in-channel command does 
not initiate any i/o operation at the channel, and the 
i/o device is not signaled of the execution of the com- 
mand. The purpose of the transfer in channel com- 
mand is to provide chaining between ccw's not lo- 
cated in adjacent double-word locations in an ascend- 
ing order of addresses. The command can occur in 
both data and command chaining. 

The first ccw designated by the caw may not specify 
transfer in channel. When this restriction is violated, 
no i/o operation is initiated, and the program-check 
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condition is generated. The error causes the status por- 
tion of the csw with the program-check indication to 
be stored during the execution of start i/o. 

To address a ccw on integral boundaries for double 
words, a ccw specifying transfer in channel must con- 
tain zeros in bit positions 29-31. Furthermore, a ccw 
specifying a transfer in channel may not be fetched 
from a location designated by an immediately preced- 
ing transfer in channel. When either of these errors is 
detected or when an invalid address is specified in 
transfer in channel, the program-check condition is 
generated. When the transfer-in-channel command 
designates a ccw in a location protected for fetching, 
the protection-check condition is generated. Detec- 
tion of these errors during data chaining causes the 
operation at the i/o device to be terminated, whereas 
during command chaining they cause an interruption 
condition to be generated. 

The contents of the second half of the ccw, bit po- 
sitions 32-63, are ignored. Similarly, the contents of bit 
positions 0-3 of the ccw are ignored. 

Termination of Input/Output Operations 

When the operation or sequence of operations initiated 
by STABT i/o is terminated, the channel and the device 
generate status conditions. These conditions can be 
brought to the attention of the progranT by means of 
an i/o interruption, by test i/o, or, in certain cases, by 
START i/o. The status conditions, as well as an address 
and a count indicating the extent of the operation 
sequence, are presented to the program in the form of 
a channel status word (csw). 

Types of Termination 

Normally an i/o operation at the subchannel lasts until 
the device signals channel end. The channel-end con- 
dition can be signaled during the sequence initiating 
the operation, or later. When the channel detects 
equipment malfunctioning or a system reset is per- 
formed, the channel disconnects the device without 
receiving channel end. The program can force a de- 
vice on the selector channel to be disconnected pre- 
maturely by issuing halt i/o. 

Termination at Operation Initiation 

After the addressed channel and subchannel have been 
verified to be in a state where start i/o can be exe- 
cuted, certain tests are performed on the validity of 
the infonnation specified by the program and on the 
availability of the addressed control unit and i/o de- 
vice. This testing occurs both during the execution of 
start i/o and during command chaining. 

A data-transfer operation is initiated at the subchan- 
nel and device only when no programming or equip- 



ment errors are detected by the channel and when the 
device responds with zero status during the initiation 
sequence. When the channel detects or the device sig- 
nals any unusual condition during the initiation of an 
operation, but channel end is oflF, the command is said 
to be rejected. 

Rejection of the command during the execution of 
START i/o is indicated by the setting of the condition 
code in the psw. Unless the device is not operational, 
the conditions that precluded the initiation are de- 
tailed by the portion of the csw stored by start i/o. 
The device is not started, no interruption conditions 
are generated, and the subchannel is not tied up be- 
yond the initiation sequence. The device is immedi- 
ately available for the initiation of another operation, 
provided the command was not rejected because of 
the busy or non-operational condition. 

When an unusual condition causes a command to be 
rejected during initiation of an i/o operation by com- 
mand chaining, an interruption condition is generated, 
and the subchannel is not available until the condition 
is cleared. The conditions are indicated to the program 
by means of the corresponding status bits in the csw. 
The not-operational condition, which during the exe- 
cution of START i/o causes condition code 3 to be set, 
is indicated by means of the interface-control-check 
bit. The new operation at the i/o devices is not started. 

Immediate Operations 

Instead of accepting or rejecting a command, the i/o 
device can signal the channel-end condition immedi- 
ately upon receipt of the command code. An i/o op- 
eration causing the channel-end condition to be sig- 
naled during the initiation sequence is called an 
"immediate operation." 

When the first ccw designated by the caw initiates 
an immediate operation, no interruption condition is 
generated. If no command chaining occurs, the chan- 
nel-end condition is brought to the attention of the 
program by causing start i/o to store the csw status 
portion, and the subchannel is immediately made a^^ail- 
able to the program. The i/o operation, howevei", is 
initiated, and, if channel-end is not accompanied by 
device end, the device remains busy. Device end, when 
subsequently provided by the device, causes an inter- 
ruption condition to be generated. 

When command chaining is specified after an im- 
mediate operation and no unusual conditions have 
been detected during the execution, start i/o does not 
cause storing of csw status. The subsequent commands 
in the chain are handled normally, and the channel-end 
condition for the last operation generates an inter- 
ruption condition even if the device provides the sig- 
nal immediately upon receipt of the command code. 
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whenever immediate completion of an i/o oper- 
ation is signaled, no data have been transferred to or 
from the device. The data address in the ccw is not 
checked for validity, except that it may not exceed 
the addressing capacity of the model. 

Since a count of zero is not valid, any ccw specifying 
an immediate operation must contain a nonzero count. 
When an immediate operation is executed, however, 
incorrect length is not indicated to the program, and 
command chaining is performed when so specified. 

Programming Note 

Control operations for which the entire operation is 
specified in the command code may be executed as 
immediate operations. Whether the control function is 
executed as an immediate operation depends on the 
operation and type of device and is specified in the srl 
publication for the device. 

Terminafion of Data Transfer 

When the device accepts a command, the subchannel 
is set up for data transfer. The subchannel is said to 
be working during this period. Unless the channel de- 
tects equipment malfunctioning or, on the selector 
channel, the operation is terminated by halt i/o, the 
working state lasts until the channel receives the chan- 
nel-end signal from the device. When no command 
chaining is specified or when chaining is suppressed 
because of unusual conditions, the channel-end con- 
dition causes the operation at the subchannel to be ter- 
minated and an interruption condition to be generated. 
The status bits in the associated csw indicate channel 
end and the unusual conditions, if any. The device can 
signal channel end at any time after initiation of the 
operation, and the signal may occur before any data 
have been transferred. 

For operations not involving data transfer, the de- 
vice normally controls the timing of the channel-end 
condition. The duration of data transfer operations 
may be variable and may be controlled by the device 
or the channel. 

Excluding equipment errors and halt i/o, the chan- 
nel signals the device to terminate data transfer when- 
ever any of the following conditions occurs: 

The storage areas specified for the operation are 

exhausted or filled. 
Program-check condition is detected. 
Protection-check condition is detected. 
Chaining-check condition is detected. 

The first of these conditions occurs when the channel 
has stepped the count in the last ccw associated with 
the operation to zero. A count of zero indicates that 
the channel has transferred all information specified 
by the program. The other three conditions are due to 



errors and cause premature termination of data trans- 
fer. In either case, the termination is signaled in re- 
sponse to a service request from the device and causes 
data transfer to cease. If the device has no blocks de- 
fined for the operation (such as writing on magnetic 
tape), it terminates the operation and generates the 
channel-end condition. 

The device can control the duration of an operation 
and the timing of channel end by blocking of data. On 
certain operations for which blocks are defined ( such 
as reading on magnetic tape), the device does not 
provide the channel-end signal until the end of the 
block is reached, regardless of whether or not the de- 
vice has been previously signaled to terminate data 
transfer. 

The channel suppresses initiation of an i/o operation 
when the data address in the first ccw associated with 
the operation exceeds the addressing capacity of the 
model. Complete check for the validity of the data ad- 
dress is performed only as data are transferred to or 
from main storage. When the initial data address in 
the ccw is invalid, no data are transferred during the 
operation, and the device is signaled to terminate the 
operation in response to the first service request. On 
writing, devices such as magnetic tape units request 
the first byte of data before any mechanical motion is 
started and, if the initial data address is invalid, the 
operation is terminated before the recording medium 
has been advanced. However, since the operation has 
been initiated, the device provides channel end, and 
an interruption condition is generated. Whether a 
block at the device is advanced when no data are 
transferred depends on the type of device and is speci- 
fied in the srl publication for the device. 

When command chaining takes place, the subchan 
nel appears in the working state from the time the 
first operation is initiated until the device signals the 
channel-end condition of the last operation of the 
chain. On the selector channel, the device executing 
the operation stays connected to the channel and the 
whole channel appears to be in the working state for 
the duration of the execution of the chain of oper- 
ations. On the multiplexor channel an operation in the 
burst mode causes the channel to appear to be in the 
working state only for the duration of the transfer of 
the burst of data. If channel end and device end do 
not occur concurrently, the device disconnects from 
the channel after providing channel end, and the chan- 
nel can in the meantime communicate with other de- 
vices on the interface. 

Any unusual conditions cause command chaining to 
be suppressed and an interruption condition to be gen- 
erated. The unusual conditions can be detected by 
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either the channel or the device, and the device can 
provide the indications with channel end, control unit 
end, or device end. When the channel is avi^are of the 
unusual condition by the time the channel-end signal 
for the operation is received, the chain is terminated 
as if the operation during which the condition oc- 
curred were the last operation of the chain. The de- 
vice-end signal subsequently is processed as an inter- 
ruption condition. When the device signals unit check 
or unit exception with control unit end or device end, 
the subchannel terminates the working state upon re- 
ceipt of the signal from the device. The channel-end 
indication in this case is not made available to the 
program. 

Termination by HALT I/O 

The instruction halt i/o causes the current operation 
at the addressed channel or subchannel to be termi- 
nated immediately. The method of termination diflfers 
from that used upon exhaustion of count or upon de- 
tection of programming errors to the extent that ter- 
mination by HALT i/o is not contingent on the receipt 
of a service request from the device. 

When HALT i/o is issued to a channel operating in 
the burst mode, the channel issues the halt-i/o signal 
to the device regardless of the current activity in the 
channel and on the interface. If the channel is involved 
in the data-transfer portion of an operation, data trans- 
fer is immediately terminated, and the device is dis- 
connected from the channel. If halt i/o is addressed 
to a selector channel executing a chain of operations 
and the device has already provided channel end for 
the current operation, the instruction causes the de- 
vice to be disconnected and the chain-command flag 
to be removed. 

When HALT i/o is issued to the multiplexor channel 
and the channel is not operating in the burst mode, 
HALT i/o causes the device to be selected, and the 
halt-i/o signal is issued as the device responds. When 
command chaining is indicated in the subchannel, 
HALT i/o causes the chain-command flag to be turned 
off. 

Termination of an operation by halt i/o on the se- 
lector channel results in up to four distinct interrup- 
tion conditions. The first one is generated by the chan- 
nel upon execution of the instruction and is not con- 
tingent on the receipt of status from the device. Tlie 
command address and count in the associated csw 
indicate how much data have been transferred, and 
the channel-status bits reflect the unusual conditions, 
if any, detected during the operation. If halt i/o is 
issued before all data specified for the operation have 
been transferred, incorrect length is indicated, subject 
to the control of the sli flag in the current ccw. The 



execution of halt i/o itself is not reflected in csw 
status, and all status bits in a csw due to this inter- 
ruption condition can be zero. The channel is available 
for the initiation of a new i/o operation as soon as the 
interruption condition is cleared. 

The second interruption condition on the selector 
channel occurs when the control unit generates tne 
channel-end condition. The selector channel handles 
this condition as any other interruption condition from 
the device after the device has been disconnected from 
the channel, and provides zeros in the protection key, 
command address, count, and channel status fields of 
the associated csw. The channel-end condition is not 
made available to the program when halt i/o is issued 
to a channel executing a chain of operations and the 
device has already provided channel end for the cur- 
rent operation. 

Finally, the third and fourth interruption conditions 
occur when control unit end, if any, and device end 
are generated. These conditions are handled as for any 
other i/o operation. 

Termination of an operation by halt i/o on the 
multiplexor channel causes the normal interruption 
conditions to be generated. If the instruction is issued 
when the subchannel is in the data-transfer portion of 
an operation, the subchannel remains in the working 
state until channel end is signaled by the device, at 
which time the subchannel is placed in the interrup- 
tion-pending state. If HALT i/o is issued after the de- 
vice has signaled channel end and the subchannel is 
executing a chain of operations, the channel-end con- 
dition is not made available to the program, and the 
subchannel remains in the working state until the next 
status byte from the device is received. Receipt of a 
status byte subsequently places the subchannel in the 
interruption-pending state. 

The csw associated with the interruption condition 
in the subchannel contains the status bytes provided 
by the device and the channel, and indicates at what 
point data transfer was terminated. If halt i/o is is- 
sued before all data areas associated with the current 
operation have been exhausted or filled, incorrect 
length is indicated, subject to the control of the sli 
flag in the current ccw. The interruption condition is 
processed as for any other type of termination. 

Programming Note 

The csw associated with a write operation terminated 
by halt i/o indicates how many bytes the channel 
has sent to the device. Since the execution of halt i/o 
may cause the loss of the byte of data in transit over 
the i/o interface and may cause the device to suppress 
recording of data contained in its buffer, if any, all 
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bytes that have left the channel may not necessarily 
be recorded at the i/o device. 

Termination Due to Equipment Malfunction 

When channel equipment malfunctioning is detected 
or invalid signals are received over the i/o interface, 
the recovery procedure and the subsequent states of 
the subchannels and devices on the channel depend 
on the type of error and on the model. Normally, the 
program is alerted of the termination by an i/o inter- 
ruption, and the associated csvi' indicates the channel- 
control-check or interface-control-check condition. In 
channels sharing common equipment with the cpu, 
malfunctioning detected by the channel may be indi- 
cated by a machine-check interruption, in which case 
no csw is stored. Equipment malfunctioning may cause 
the channel to perform the malfunction-reset function. 

Input/ Output Interruptions 

Input/output interruptions provide a means for the 
CPU to change its state in response to conditions that 
occur in i/o devices or channels. These conditions can 
be caused by the program or by an external event at 
the device. 

Interruption Conditions 

The conditions causing requests for i/o interruptions 
to be initiated are called i/o interruption conditions. 
An i/o interruption condition can be brought to the 
attention of the program only once and is cleared 
when it causes an interruption. Alternatively, an i/o 
interruption condition can be cleared by test i/o, and 
conditions generated by the i/o device following the 
termination of the operation at the subchannel can be 
cleared by start i/o. The latter include the attention, 
device-end, and control-unit-end conditions, and the 
channel-end condition when provided by a device on 
the selector channel after termination of the operation 
by HALT i/o. 

The device attempts to initiate a request to the 
channel for an interruption whenever it detects any 
of the following conditions: 

Channel end 

Control-unit end 

Device end 

Attention 

The device may also, at command chaining, have 
created an interruption condition at the device, which 
can be due to the following conditions: 

Unit check 

Unit exception 

Busy indication from device 

Program check 

Protection check 



When an operation initiated by command chaining 
is terminated because of an unusual condition detected 
during the command initiation sequence, the interrup- 
tion condition may remain pending within the chan- 
nel, or the channel may create an interruption condition 
at the device. An interruption condition is created at 
the device in response to presentation of status by the 
device and causes the device subsequently to present 
the same status for interruption purposes. The inter- 
ruption condition at the device may or may not be 
associated with unit status. If the unusual condition is 
detected by the device (unit check, unit exception, or 
busy ) the unit-status field of the associated csw iden- 
tifies the condition. In the case of program and pro- 
tection check, the identification of the error condition 
is preserved in the subchannel, and appears in the 
channel-status field of the associated csw. If the as- 
sociated interruption condition has been queued at 
the device, the device provides zero status for inter- 
ruption purposes. When command chaining takes 
place, channel end and device end do not cause an 
interruption, and are not made available. 

An interruption condition caused by the device may 
be accompanied by channel and other unit status con- 
ditions. Furthermore, more than one interruption con- 
dition associated with the same device can be cleared 
at the same time. As an example, when the channel- 
end condition is not cleared at the device by the time 
device end is generated, both conditions may be indi- 
cated in the csw and cleared at the device concur- 
rently. 

However, at the time the channel assigns highest 
priority for interruptions to a condition associated 
with an operation at the subchannel, the channel ac- 
cepts the status from the device and clears the condi- 
tion at the device. The interruption condition and the 
associated status indication are subsequently preserved 
in the subchannel. Any subsequent status generated 
by the device is not included with the condition at 
the subchannel, even if the status is generated before 
the CPU accepts the condition. 

When the channel detects any of the following con- 
ditions, it initiates a request for an i/o interruption 
without communicating and without having received 
the status byte from the device: 

PCI Flag in a CCW 

Execution of HALT I/O on a selector channel 

The interruption conditons from the channel can be 
accompanied by other channel status indications, but 
none of the device status bits is on when the channel 
initiates the interruption. 

The method of processing a request for interrup- 
tion due to equipment malfunctioning depends on the 
model. In channels sharing common equipment with 
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the CPU, malfunctioning detected by the channel may 
be indicated by causing a machine-check interruption. 

Priorify of Interruptions 

All requests for i/o interruption are asynchronous to 
the activity in the cpu, and interruption conditions as- 
sociated with more than one i/o device can exist at 
the same time. The priority among requests is con- 
trolled by two types of mechanisms — one establishes 
the priority among interruption conditions associated 
with devices attached to the same channel, and another 
establishes priority among requests from different 
channels. A channel requests an i/o interruption only 
after it has established priority among requests from 
its devices. The conditions responsible for the requests 
are preserved in the devices or channels until accepted 
by the cpu. 

Assignment of priority to requests for interruption 
associated with devices on any one channel is a func- 
tion of the type of interruption condition and the po- 
sition of the device on the i/o interface cable. A de- 
vice's position on the cable is not related to its address. 

The selector channel assigns the highest priority to 
conditions associated with the portion of the operation 
in which the channel is involved. These conditions in- 
clude channel end, program-controlled interrup- 
tion, execution of halt i/o in the channel, and errors 
prematurely terminating a chain of operations. The 
selector channel cannot handle any interruption condi- 
tions other than those due to the pci flag while opera- 
tion is in progress. 

As soon as the selector channel has cleared the in- 
terruption conditions associated with data transfer, it 
starts monitoring devices for attention, control-unit-end, 
and device-end conditions and for the channel-end 
condition associated with operations terminated by 
HALT i/o. The highest priority is assigned to the i/o 
device that first identifies itself on the interface. 

On the multiplexor channel the priority among re- 
quests for interruption is based only on response from 
devices. The highest priority is assigned to the device 
that first identifies itself with an interruption condition 
or that requests service for data transfer and contains 
the PCI condition in the subchannel. The pci, as well 
as any other condition in the subchannel, cannot cause 
an i/o interruption unless the device initiates a refer- 
ence to the subchannel. 

Except for conditions associated with termination of 
data transfer, the current assignment of priority for 
interruption among devices on a channel may be can- 
celed when START i/o, test i/o, or halt i/o is issued 
to the channel. Whenever the assignment is canceled, 
the channel resumes monitoring for interruption con- 



ditions and reassigns the priority on completion of the 
activity associated with the i/o instruction. 

The assignment of priority among requests for inter- 
ruption from channels is based on the type of channel 
and its address assignment. The priorities of channels 
1-6 are in the order of their addresses, with channel 1 
having the highest priority. '^Fhe interruption priority 
of multiplexor channel is not fixed, and depends on 
the model and on the current activity in the channel. 
Its priority may be above, below, or between those of 
channels 1-6. 

Interruption Action 

An i/o interruption can occur only when the channel 
accommodating the device is not masked and after the 
execution of the current instruction in the cpu has 
been terminated. If a channel has established the 
priority among requests for interruption from devices 
while it is masked, the interruption occurs immediate- 
ly after the termination of the instruction removing 
the mask and before the next instruction is executed. 
This interruption is associated with the highest priority 
condition on the channel. If more than one channel is 
unmasked concurrently, the interruption occurs from 
the channel having the highest priority among those 
requesting interruption. 

If the priority among interruption conditions has not 
yet been established in the channel by the time the 
mask is removed, the interruption does not necessarily 
occur immediately after the termination of the instruc- 
tion removing the mask. This delay can occur regard- 
less of how long the interruption condition has existed 
in the device or the subchannel. 

The interruption causes the current program status 
word ( psw ) to be stored as the old psw at location 56 
and causes the csw associated with the interruption to 
be stored at location 64. Subsequently, a new psw is 
loaded from location 120, and processing resumes in 
the state indicated by this Psw. The i/o device or, in 
the case of control unit end, the control unit causing 
the interruption is identified by the channel address in 
bit positions 16-23 and by the device address in bit 
positions 24-31 of the old psw. The csw associated 
with the interruption identifies the condition respon- 
sible for the interruption and provides further details 
about the progress of the operation and the status of 
the device. 

Programming Note 

When a number of i/o devices on a shared control unit 
are concurrently executing operations such as rewind- 
ing tape or positioning a disk access mechanism, the 
initial device-end signals generated on completion of 
the operations are provided in the order of generation. 
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unless command chaining is specified for the operation 
last initiated. In the latter case, the control unit pro- 
vides the device-end signal for the last initiated op- 
eration first, and the other signals are delayed until 
the subchannel is freed. Whenever interruptions due 
to the device-end signals are delayed either because 
the channel is masked or the subchannel is busy, the 
original order of the signals is destroyed. 

Channel Status Word 

The channel status word (csw) provides to the pro- 
gram the status of an i/o device or the conditions 
under which an i/o operation has been terminated. 
The csw is formed, or parts of it are replaced, in the 
process of i/o interruptions and during execution of 
START i/o, TEST i/o, and HALT i/o. The csw is placed in 
main storage at location 64 and is available to the pro- 
gram at this location until the time the next i/o inter- 
ruption occurs or until another i/o instruction causes 
its content to be replaced, whichever occurs first. 

When the csw is stored as a result of an i/o inter- 
ruption, the i/o device is identified by the i/o address 
in the old psw. The information placed in the csw by 
START i/o, TEST i/o, or HALT i/o pertains to the device 
addressed by the instruction. 

The csw has the following format: 



Key 


0000 


Command Address 


3 4 7 8 




31 


Status 


Count 



The. fields in the csw are allocated for the following 
purposes: 

Protection Key: Bits 0-3 form the protection key 
used in the chain of operations at the subchannel. 

Command Address: Bits 8-31 form an address that 
is eight higher than the address of the last ccw used. 

Status: Bits 32-47 identify the conditions in the de- 
vice and the channel that caused the storing of the 
csw. Bits 32-39 are obtained over the i/o interface and 
indicate conditions detected by the device or the con- 
trol unit. Bits 40-47 are provided by the channel and 
indicate conditions associated with the subchannel. 
Each of the 16 bits represents one type of condition, 
as follows : 



BIT 


DESIGNATION 


BIT 


DESIGNATION 


32 


Attention 


40 


Program-controlled 
interruption 


33 


Status modifier 


41 


Incorrect length 


34 


Control unit end 


42 


Program check 


35 


Busy 


43 


Protection check 


36 


Channel end 


44 


Channel data check 


37 


Device end 


45 


Channel control check 


38 


Unit check 


46 


Interface control check 


39 


Unit exception 


47 


Chaining check 



Count: Bits 48-63 form the residual count for the 
last ccw used. 

Unit Status Conditions 

The following conditions are detected by the i/o de- 
vice or control unit and are indicated to the channel 
over the i/o interface. The timing and causes of these 
conditions for each type of device are specified in the 
SRL publication for the device. 

When the i/o device is accessible from more than 
one channel, status due to channel-initiated operations 
is signaled to the channel that initiated the associated 
i/o operation. The handling of conditions not associ- 
ated with i/o operations, such as attention or device 
end due to transition from the not-ready to the ready 
state, depends on the type of device and condition and 
is specified in the srl publication for the device. 

The channel does not modify the status bits received 
from the i/o device. These bits appear in the csw as 
received over the interface. 

Attention 

Attention is generated when the device detects an 
asynchronous condition that is significant to the pro- 
gram. The condition is interpreted by the program 
and is not associated with the initiation, execution, or 
termination of an i/o operation. 

The device can signal the attention condition to the 
channel only when no operation is in progress at the 
i/o device, control unit, or subchannel. Attention can 
be indicated with device end upon completion of an 
operation, and it can be presented to the channel 
during the initiation of a new i/o operation. Other- 
wise, the handling and presentation of the condition 
to the channel depends on the type of device. 

When the device signals attention during the initi- 
ation of an operation, the operation is not initiated. 
Attention accompanying device end causes command 
chaining to be suppressed. 

Status Modifier 

Status modifier is generated by the device when the 
device cannot provide its current status in response to 
TEST i/o, to indicate that the control unit is busy, or 
when the normal sequence of commands has to be 
modified. 

When the status-modifier condition is signaled in 
response to test i/o and the bit appears in the csw in 
the absence of any other status bit, presence of the bit 
indicates that the device cannot execute the instruction 
and has not provided its current status. The interrup- 
tion condition, which may be pending at the device or 
subchannel, has not been cleared, and the csw stored 
by TEST i/o contains zeros in the key, command ad- 
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dress, and count fields. The 2702 Transmission Con- 
trol is an example of a type of device that cannot 
execute test i/o. 

When the status-modifier bit appears in the csw to- 
gether with the busy bit, it indicates that the busy 
condition pertains to the control unit associated with 
the addressed i/o device. The control unit appears 
busy when it is executing a type of operation that pre- 
cludes the acceptance and execution of any command 
or the instructions test i/o and halt i/o or contains 
an interruption condition for a device other than one 
addressed. The interruption condition may be due to 
control unit end or, on the selector channel, due to 
channel end following the execution of halt i/o. The 
busy state occurs for operations such as backspace 
tape file, in which case the control unit remains busy 
after providing channel end, for operations terminated 
on the selector channel by halt i/o, and temporarily 
occurs on the 2702 Transmission Control after initia- 
tion of an operation on a device accommodated by the 
control unit. A control unit accessible from two or 
more channels appears busy when it is communicating 
with another channel. 

Presence of the status modifier and device end 
means that the normal sequence of commands must 
be modified. The handling of this set of bits by the 
channel depends on the operation. If command chain- 
ing is specified in the current ccw and no unusual con- 
ditions have been detected, presence of status modi- 
fier and device end causes the channel to fetch and 
chain to the ccw whose main-storage address is 16 
higher than that of the current ccw. If the i/o device 
signals the status-modifier condition at a time when no 
command chaining is specified, or when any unusual 
conditions have been detected, no action is taken in 
the channel, and the status-modifier bit is placed in the 
csw. 

Programming Note 

When the multiplexor channel detects a programming 
error during command chaining, the interruption con- 
dition is queued at the i/o device. On devices such as 
the 2702 Transmission Control, queuing of the con- 
dition may generate the status-modifier indication, 
which subsequently appears in the csw associated 
with the termination of the operation. 

Control Unit End 

Control unit end indicates that the control unit has 

become available for use for another operation. 

The control-unit-end condition is provided only by 
control units shared by i/o devices and only when one 
or both of the following conditions has occurred: 

1. The program had previously caused the control 
unit to be interrogated while the control unit was in 



the busy state. The control unit is considered to have 
been interrogated in the busy state when a command 
or the instructions test i/o or halt i/o had been issued 
to a device on the control unit, and the control unit 
had responded with busy and status modifier in the 
unit status byte. See "Status Modifier." 

2. The control unit detected an unusual condition 
during the portion of the operation after channel end 
had been signaled to the channel. The indication of 
the unusual condition accompanies control unit end. 

If the control unit remains busy with the execution 
of an operation after signaling channel end but has not 
been interrogated by the program, control unit end 
is not generated. Similarly, control unit end is not pro- 
vided when the control unit has been interrogated and 
could perform the indicated function. The latter case 
is indicated by the absence of busy and status modi- 
fier in the response to the instruction causing the in- 
terrogation. 

When the busy state of the control unit is tem- 
porary, control unit end is included with busy and 
status modifier in response to the interrogation even 
though the control unit has not yet been freed. The 
busy condition is considered to be temporary if its 
duration is commensurate with the program time 
required to handle an i/o interruption. The 2702 
Transmission Control is an example of a device in 
which the control unit may be busy temporarily and 
which includes control unit end with busy and status 
modifier. 

The control-unit-end condition can be signaled with 
channel end, device end, or between the two. When 
control unit end is signaled by means of an i/o inter- 
ruption in the absence of any other status conditions, 
the interruption may be identified by any address as- 
signed to the control unit. A pending control unit end 
causes the control unit to appear busy for initiation of 
new operations. 

Busy 

Busy indicates that the i/o device or control unit (can- 
not execute the command or instruction because it is 
executing a previously initiated operation or because 
it contains a pending interruption condition. The in- 
terruption condition for the addressed device, if any, 
accompanies the busy indication. If the busy condition 
applies to the control unit, busy is accompanied by 
status modifier. 

The following table lists the conditions when the 
busy bit (b) appears in the csw and when it is ac- 
companied by the status-modifier bit (sm). A double 
hyphen (~) indicates that the busy bit is off; an 
asterisk ( * ) indicates that csw status is not stored or 
an i/o interruption cannot occur; and the (cl) indi- 
cates that the interruption condition is cleared and 
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the status appears in the csw. The abbreviation de 
stands for device end, while cu stands for control unit. 



CONDITION 



CSW STATUS STORED BY: 
START TEST HALT l/O 
l/O I/O I/O INT. 



Subchannel available 






DE or attention in device 


B,cl 


--,cl 


Device working, CU available 


B 


B 


CU end or channel end in CU: 






for the addressed device 


B,cl 


--,cl 


for another device 


B,SM 


B,SM 


CU working 


B,SM 


B,SM 


Interruption pend. in subchannel 






for the addressed device 






because of: 






chaining terminated by 






busy condition 


« 


B,cl 


other type of termination 


» 


--,cl 


Subchannel working 






CU available 


» 


# 


CU working 


* 


» 



-,cl 



-,cl 
-.cl 



B,cl 
--,cl 



B,SM * 



Channel End 

Channel end is caused by the completion of the por- 
tion of an i/o operation involving transfer of data or 
control information between the i/o device and the 
channel. The condition indicates that the subchannel 
has become available for use for another operation. 

Each i/o operation causes a channel-end condition 
to be generated, and there is only one channel end for 
an operation. The channel-end condition is not gen- 
erated when programming errors or equipment mal- 
functions are detected during initiation of the opera- 
tion. When command chaining takes place, only the 
channel end of the last operation of the chain is made 
available to the program. The channel-end condition 
is not made available to the program when a chain of 
commands is prematurely terminated because of an 
unusual condition indicated with control unit end or 
device end or during the initiation of a chained com- 
mand. 

The instant within an i/o operation when channel 
end is generated depends on the operation and the 
type of device. For operations such as writing on mag- 
netic tape, the channel-end condition occurs when the 
block has been written. On devices that verify the 
writing, channel end may or may not be delayed until 
verification is performed, depending on the device. 
When magnetic tape is being read, the channel-end 
condition occurs when the gap on tape reaches the 
read-write head. On devices equipped with buffers, 
such as the ibm 1443 Nl Printer ( bar line printer ) , the 
channel-end condition occurs upon completion of data 
transfer between the channel and the buffer. During 
control operations, channel end is generated when the 
control information has been transferred to the de- 
vices, although for short operations the condition may 
be delayed until completion of the operation. Opera- 



tions that do not cause any data to be transferred can 
provide the channel-end condition during the initia- 
tion sequence. 

A channel-end condition pending in the control unit 
causes the control unit to appear busy for initiation of 
new operations. Unless the operation has been per- 
formed on the selector channel and has been termi- 
nated by HALT i/o,. a pending channel end causes the 
subchannel to be in the interruption-pending state. 

Device End 

Device end is caused by the completion of an i/o op- 
eration at the device or, on some devices, by manually 
changing the device from the not-ready to the ready 
state. The condition normally indicates that the i/o 
device has become available for use for another 
operation. 

Each i/o operation causes a device-end condition, 
and there is only one device-end to an operation. The 
device-end condition is not generated when any pro- 
gramming or equipment malfunction is detected 
during initiation of the operation. When command 
chaining takes place, only the device-end of the last 
operation of the chain is made available to the 
program unless an unusual condition is detected dur- 
ing the initiation of a chained command, in which case 
the chain is terminated without the device-end indica- 
tion. 

The device-end condition associated with an i/o 
operation is generated either simultaneously with the 
channel-end condition or later. On data transfer op- 
erations on devices such as magnetic tape units, the 
device terminates the operation at the time channel 
end is generated, and both device end and channel 
end occur together. On buffered devices, such as an 
IBM 1443 Printer, the device-end condition occurs upon 
completion of the mechanical operation. For control 
operations, device end is generated at the completion 
of the operation at the device. The operation may be 
completed at the time channel end is generated or 
later. 

When command chaining is specified in the sub- 
channel, receipt of the device-end signal, in the ab- 
sence of any unusual conditions, causes the channel to 
initiate a new i/o operation. 

Unit Check 

Unit check indicates that the i/o device or control unit 
has detected an unusual condition that is detailed by 
the information available to a sense command. Unit 
check may indicate that a programming or an equip- 
ment error has been detected, that the not-ready state 
of the device has affected the execution of the com- 
mand or instruction, or that an exceptional condition 
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other than the one identified by unit exception has 
occurred. The unit-check bit provides a summary indi- 
cation of the conditions identified by sense data. 

An error condition causes the unit-check indication 
only when it occurs during the execution of a com- 
mand or TEST i/o, or during some activity associated 
with an i/o operation. Unless the error condition per- 
tains to the activity initiated by a command and is of 
immediate significance to the program, the condition 
does not cause the program to be alerted after device 
end has been cleared; a malfunction may, however, 
cause the device to become not ready. 

Unit check is indicated when the existence of the 
not-ready state precludes a satisfactory execution of 
the command, or when the command, by its nature, 
tests the state of the device. When no interruption con- 
dition is pending for the addressed device at the con- 
trol unit, the control unit signals unit check when test 
i/o or the no-operation control command is issued to a 
not-ready device. In the case of no operation, the 
command is rejected, and channel end and device end 
do not accompany unit check. 

Unless the command is designed to cause unit check, 
such as rewind and unload on magnetic tape, unit 
check is not indicated if the command is properly exe- 
cuted even though the device has become not ready 
during or as a result of the operation. Similarly, unit 
check is not indicated if the command can be executed 
with the device not ready. The ibm 2150 Console, for 
example, accepts and executes the alarm control com- 
mand when the printer is not ready. Selection of a de- 
vice in the not-ready state does not cause a unit-check 
indication when the sense command is issued, and 
whenever an interruption condition is pending for the 
addressed device at the control unit. 

If the device detects during the initiation sequence 
that the command cannot be executed, unit check is 
presented to the channel and appears without channel 
end, control unit end, or device end. Such unit status 
indicates that no action has been taken at the device 
in response to the command. If the condition preclud- 
ing proper execution of the operation occurs after exe- 
cution has been started, unit check is accompanied by 
channel end, control unit end, or device end, depend- 
ing on when the condition was detected. Any errors 
associated with an operation, but detected after de- 
vice end has been cleared, are indicated by signaling 
unit check with attention. 

Errors, such as invalid command code or invalid 
command code parity, do not cause unit check when 
the device is working or contains a pending interrup- 
tion condition at the time of selection. Under these 
circumstances, the device responds by providing the 
busy bit and indicating the pending interruption con- 



dition, if any. The command code invalidity is not 
indicated. 

Termination of an operation with the unit-check 
indication causes command chaining to be suppressed. 

Programming Note 

If a device becomes not ready upon completion of a 
command, the ending interruption condition can be 
cleared by test i/o without generation of unit check 
due to the not-ready state, but any subsequent test i/o 
issued to the device causes a unit-check indication. 

Unit Exception 

Unit exception is caused when the i/o device detects 

a condition that usually does not occur. Unit exception 

includes conditions such as recognition of a tape mark 

and does not necessarily indicate an error. It has only 

one meaning for any particular command and type of 

device. 

The unit-exception condition can be generated only 
when the device is executing an i/o operation, or when 
the device involved with some activity associated with 
an i/o operation and the condition is of immediate 
significance to the program. If the device detects 
during the initiation sequence that the operation can- 
not be executed, unit exception is presented to the 
channel and appears without channel end, control unit 
end, or device end. Such unit status indicates that no 
action has been taken at the device in response to the 
command. If the condition precluding normal execu- 
tion of the operation occurs after the execution has 
been started, unit exception is accompanied by channel 
end, control unit end, or device end, depending on 
when the condition was detected. Any unusual condi- 
tions associated with an operation, but detected after 
device-end has been cleared; is indicated by signaling 
unit exception with attention. 

A command does not cause unit exception when the 
device responds during the initial selection with busy 
status to the command. 

Termination of an operation with the unit-exception 
indication causes command chaining to be suppressed. 

Channel Status Conditions 

The following conditions are detected and indicated by 
the channel. Except for the conditions caused by equip- 
ment malfunctioning, they can occur only while the 
subchannel is involved with the execution of an i/o 
operation. 

Program-Controlled Interruption 

The program-controlled-interruption condition is gen- 
erated when the channel fetches a ccw with the pro- 
gram-controlled-interruption (pci) flag on. The inter- 
ruption due to the pci flag takes place as soon as 
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possible after the ccw takes control of the operation 
but may be delayed an unpredictable amount of time 
because of masking of the channel or other activity in 
the system. 

Detection of the pci condition does not affect the 
progress of the i/o operation. 

Incorrect Length 

Incorrect length occurs when the number of bytes con- 
tained in the storage areas assigned for the i/o oper- 
ation is not equal to the number of bytes requested or 
offered by the i/o device. Incorrect length is indicated 
^ for one of the following reasons: 

Long Block on Input: During a read, read-backward, 
or sense operation, the device attempted to transfer 
one or more bytes to storage after the assigned storage 
areas were filled. The extra bytes have not been placed 
in main storage. The count in the csw is zero. 

Long Block on Output: During a write or control 
operation the device requested one or more bytes from 
the channel after the assigned main-storage areas were 
exhausted. The count in the csw is zero. 

Short Block on Input: The number of bytes trans- 
ferred during a read, read backward, or sense oper- 
ation is insufficient to fill the storage areas assigned to 
the operation. The count in the csw is not zero. 

Short Block on Output: The device terminated a 
write or control operation before all information con- 
tained in the assigned storage areas was transferred to 
the device. The count in the csw is not zero. 

The incorrect-length indication is suppressed when 
the current ccw has the sli flag and does not have the 
CD flag. The indication does not occur for immediate 
operations and for operations rejected during the ini- 
tiation sequence. 

Presence of the incorrect-length condition suppresses 
command chaining unless the sli flag in the ccw is on 
or unless the condition occurs in an immediate oper- 
ation. See the table in the Chaining section of this 
manual for the effect of the cd, cc, and sli flags on the 
indication of incorrect length. 

Program Check 

Program check occurs when programming errors are 
detected by the channel. The condition can be due to 
the following causes: 

Invalid CCW Address Specification: The caw or the 
transfer-in-channel command does not designate the 
ccw on integral boundaries for double words. The 
three low-order bits of the ccw address are not zero. 

Invalid CCW Address: The channel has attempted 
to fetch a ccw from a location outside the main stor- 
age of the particular installation. An invalid ccw ad- 
dress can occur in the channel because the program 
has specified an invalid address in the caw or in the 



transfer-in-channel command or because on chaining 
the channel has stepped the address above the highest 
available location. 

Invalid Command Code: The command code in the 
first ccw designated by the caw or in a ccw fetched on 
command chaining has four low-order zeros. The com- 
mand code is not tested for validity during data chain- 
ing. 

Invalid Count: A ccw other than a ccw specifying 
transfer in channel contains the value zero in bit po- 
sitions 48-63. 

Invalid Data Address: The channel has attempted 
to transfer data to or from a location outside the main 
storage of the particular installation. An invalid data 
address can occur in the channel because the program 
has specified an invalid address in the ccw or because 
the channel has stepped the address above the highest 
available address or, on reading backward, below zero. 

Invalid Key: The caw contains a nonzero storage 
protection key in a model not having the protection 
feature installed. 

Invalid CAW Format: The caw does not contain 
zeros in bit positions 4-7. 

Invalid CCW Format: A ccw other than a ccw spe- 
cifying transfer in channel does not contain zeros in 
bit positions 37-39. 

Invalid Sequence: The first ccw designated by the 
CAW specifies transfer in channel or the channel has 
fetched two successive ccw's both of which specify 
transfer in channel. 

Detection of the program-check condition during 
the initiation of an operation causes execution of the 
operation to be suppressed. When the condition is de- 
tected after the device has been started, the device is 
signaled to terminate the operation the next time it 
requests or offers a byte of data. The program-check 
condition causes command chaining to be suppressed. 

Protection Check 

Protection check occurs when the channel attempts to 
place data in or fetch data or a ccw from a portion of 
main storage that is protected for the current operation 
on the subchannel. The protection key associated with 
the i/o operation does not match the key of the ad- 
dressed main-storage location, and the protection key 
is not zero. 

When the protection-check condition occurs during 
the fetching of a ccw that specifies the initiation of an 
i/o operation, the operation is not initiated. When 
protection check is detected after the device has been 
started, the device is signaled to terminate the opera- 
tion the next time it requests or offers a byte of data. 
The condition causes command chaining to be sup- 
pressed. 
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The protection-check condition can be generated 
only on models having the protection feature installed. 

Channel Data Check 

Channel data check indicates that the channel has de- 
tected a parity error in the information transferred to 
or from main storage during an i/o operation. This in- 
formation includes the data read or written, as well as 
the information transferred as data during a sense or 
control operation. The error may have been detected 
anywhere inboard the i/o interface: in the channel, in 
main storage, or on the path between the two. Chan- 
nel data check may be indicated for parity errors de- 
tected in data that are referred to by the channel but 
do not participate in the operation. 

Whenever a parity error on i/o data is indicated by 
means of channel data check, the channel forces cor- 
rect parity on all data received over the i/o interface 
and, within the limitations of parity checking and cor- 
rection facilities of the model, correct parity is forced 
on all data placed in main storage. On an output op- 
eration, the parity of the data is not changed when 
channel data check is indicated. 

A condition indicated as channel data check causes 
command chaining to be suppressed, but does not af- 
fect the execution of the current operation. Data trans- 
fer proceeds to normal completion, and an i/o inter- 
ruption condition is generated when the device 
presents channel end. No log-out or reset occurs, and 
the detection of the error does not affect the state of 
the channel or device. 

When CPU and channel equipment is integrated to 
such an extent that a data parity error precludes con- 
tinuation of the i/o operation or handling of the parity 
bit as described above, a machine-check condition is 
generated upon the detection of the error. When a 
data parity error causes a machine-check interruption, 
reset and log-out may be performed, and the subse- 
quent recovery procedure depends on the model. 

Channel Control Cheek 

Channel control check is caused by any machine mal- 
functioning affecting channel controls. The condition 
includes parity errors on ccw and data addresses and 
parity errors on the contents of the ccw. Conditions 
responsible for channel control check may cause the 
contents of the csw to be invalid and conflicting. The 
csw as generated by the channel has correct parity. 

Detection of the channel-control-check condition 
causes the current operation, if any, to be immediately 
terminated and may cause the channel to perform the 
malfunction-reset function. The recovery procedure in 
the channel and the subsequent state of the subchannel 
upon a malfunction reset depend upon the model. 



Interface Control Check 

Interface control check is caused by any invalid signal 
on the i/o interface. The condition is detected by the 
channel and usually indicates malfunctioning of an i/o 
device. It can be due to the following reasons : 

1. The address or status byte received from a device 
has invalid parity. 

2. A device responded with an address other than 
the address specified by the channel during initiation 
of an operation. 

3. During command chaining the device appeared 
not operational. 

4. A signal from a device occurred at an invalid time 
or had invalid duration. 

Detection of the interface-control-check condition 
causes the current operation, if any, to be immediately 
terminated and may cause the channel to perform the 
malfunction-reset function. The recovery procedure in 
the channel and the subsequent state of the subchan- 
nel upon a malfunction reset depends on the model. 

Chaining Check 

Chaining check is caused by channel overrun during 
data chaining on input operations. The condition oc- 
curs when the i/o data rate is too high for the particu- 
lar resolution of data addresses. Chaining check cannot 
occur on output operations. 

Detection of the chaining-check condition causes the 
i/o device to be signaled to terminate the operation. 
It causes command chaining to be suppressed. 

Content of Channel Status Word 

The content of the csw depends on the condition caus- 
ing the storing of the csw and on the programming 
method by which the information is obtained. The 
status portion always identifies the condition that 
caused storing of the csw. The protection key, com- 
mand address, and count fields may contain informa- 
tion pertaining to the last operation or may be set to 
zero, or the original contents of these fields at location 
64 may be left unchanged. 

Information Provided by Channel Status Word 

Conditions associated with the execution or termi- 
nation of an operation at the subchannel cause the 
whole csw to be replaced. Such a csw can be stored 
only by an i/o interruption or by test i/o. Except for 
conditions associated with command chaining and 
equipment malfunctioning, the storing can be caused 
by the pci or channel-end condition and by the execu- 
tion of HALT i/o on the selector channel. The contents 
of the csw are related to the current values of the cor- 
responding quantities, although the count is unpredic- 
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table after program check, protection check, chaining 
check, and after an interruption due to the pci flag. 

A csw stored upon the execution of a chain of oper- 
ation pertains to the last operation the channel exe- 
cuted or attempted to initiate. Information concerning 
the preceding operations is not preserved and is not 
made available to the program. 

When an untisual condition causes command chain- 
ing to be suppressed, the premature termination of the 
chain is not explicitly indicated in the csw. A csw 
associated with a termination due to a condition occur- 
ing at channel-end time contains the channel-end bit 
and identifies the unusual condition. When the device 
signals the unusual condition with control unit end or 
device end, the channel-end indication is not made 
available to the program, and the channel provides the 
current protection key, command address, and count, 
as well as the unusual indication, with the control- 
unit-end or device-end bit in the csw. The command 
address and count fields pertain to the operation that 
was executed. 

When the execution of a chain of commands is ter- 
minated by an unusual condition detected during initi- 
ation of a new operation, the command address and 
count fields pertain to the rejected command. Except 
for conditions caused by equipment malfunctioning, 
termination at the initiation time can occur because of 
attention, unit check, unit exception, or program check, 
and causes both the channel-end and device-end bits 
in the csw to be turned off. 

A csw associated with conditions occurring after the 
operation at the subchannel has been terminated con- 
tains zeros in the protection key, command address, 
and count fields, provided the conditions are not 
cleared by start i/o. These conditions include atten- 
tion, control unit end, and device end (and channel 
end when it occurs after termination of an operation 
on the selector channel by halt i/o ) . 

When the above conditions are cleared by start i/o, 
only the status portion of the csw is stored, and the 
original contents of the protection key, command ad- 
dress, and count fields in location 64 are preserved. 
Similarly, only the status bits of the csw are changed 
when the command is rejected or the operation at the 
subchannel is terminated during the execution of start 
i/o or whenever halt i/o causes csw status to be 
stored. 

Errors detected during execution of the i/o oper- 
ation do not affect the validity of the csw unless the 
channel-control-check or interface-control-check con- 
ditions are indicated. Channel control check indicates 
that equipment errors have been detected, which can 
cause any part of the csw, as well as the address in the 
Fsw identifying the i/o device, to be invalid. Interface 



control check indicates that the address identifying the 
device or the status bits received from the device may 
be invalid. The channel forces correct parity on invalid 
csw fields. 

Protection Key 

A csw stored to reflect the progress of an operation at 
the subchannel contains the protection key used in 
that operation. The content of this field is not affected 
by programming errors detected by the channel or by 
the condition causing termination of the operation. 

Models in which the protection feature is not im- 
plemented cause an all-zero key to be stored. 

Command Address 

When the csw is formed to reflect the progress of the 
i/o operation at the subchannel, the command address 
is normally eight higher than the address of the last 
ccw used in the operation. 

The following table lists the contents of the com- 
mand address field for all conditions that can cause 
the csw to be stored. The conditions are listed in order 
of priority; that is, if two conditions are indicated or 
occur, the csw appears as indicated for the condition 
higher on the list. The programming errors listed in 
the table refer to conditions included in program 
check. 



CONDITION 

Channel control check 
Status stored by START I/O 
Status stored by HALT I/O 
Invalid CCW address spec in 

Transfer in channel ( TIC ) 
Invalid CCW address in TIC 
Invalid CCW address 

generated 
Invalid command code 
Invalid count 
Invalid data address 
Invalid CCW format 
Invalid sequence — 2 TIC's 
Protection check 

Chaining check 

Termination under count 
control 

Termination by I/O device 

Termination by HALT I/O 

Suppression of command 
chaining due to unit check 
or unit exception with de- 
vice end or control unit end 

Termination on command 
chaining by busy, unit 
check, or unit exception 

PCI flag in CCW 

Interface control check 

Ch end after HIO on sel ch 

Control unit end 

Device end 

Attention 

Busy 

Status modifier 



CONTENT 

Unpredictable 

Unchanged 

Unchanged 

Address of TIC + 8 
Address of TIC -f 8 
First invalid CCW address 

+8 
Address of invalid CCW + 8 
Address of invalid CCW -|- 8 
Address of invalid CCW + 8 
Address of invalid CCW + 8 
Address of second Tit) -{- 8 
Address of protected CCW 

+ 8 
Address of last-used CCW -f 8 

Address of last-used CCW + 8 
Address of last-used CCW 4- 8 
Address of last-used CCW -f 8 

Address of last CCW used in 
the completed operation -|- 8 



Address of CCW specifying 

the new^ operation -|- 8 
Address of last-used CCW + 8 
Address of last-used CCW + 8 
Zero 
Zero 
Zero 
Zero 
Zero 
Zero 
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Count 

The residual count, in conjunction with the original 
count specified in the last ccw used, indicates tlie 
number of bytes transferred to or from the area desig- 
nated by the ccw. When an input operation is termi- 
nated, the difference between the original count in the 
ccw and the residual count in the csw is equal to the 
number of bytes transferred to main storage; on an out- 
put operation, the diflFerence is equal to the number 
of bytes transferred to the i/o device. 

The following table lists the contents of the count 
field for all conditions that can cause the csw to be 
stored. The conditions are listed in the order of prior- 
ity; that is, if two conditions are indicated or occur, 
the csw appears as for the condition higher on the list. 



CONDITION 


CONTENT 


Channel control check 


Unpredictable 


Status stored by START I/O 


Unchanged 


Status stored by HALT I/O 


Unchanged 


Program check 


Unpredictable 


Protection check 


Unpredictable 


Chaining check 


Unpredictable 


Termination under count 




control 


Correct 


Termination by I/O device 


Correct 


Termination by HALT I/O 


Correct 


Suppression of command 




chaining due to unit check 


Correct. Residual count of last 


or unit exception with device 


CCW used in the completed 


end or control unit end 


operation. 


Termination on command 




chaining by busy, 


Correct. Original count of 


unit check, or unit 


CCW specifying the new 


exception 


operation. 


PCI flag in CCW 


Unpredictable 


Interface control check 


Correct 


Ch end after HIO on sel ch 


Zero 


Control unit end 


Zero 


Device end 


Zero 


Attention 


Zero 


Busy 


Zero 


Status Modifier 


Zero 



Status 



The status bits identify the conditions that have been 
detected during the i/o operation, that have caused a 



command to be rejected, or that have been generated 
by external events. 

When the channel detects several error conditions, 
all conditions may be indicated or only one may ap- 
pear in the csw, depending on the condition and 
model. Conditions associated with equipmeni; mal- 
functioning have precedence, and whenever malfunc- 
tioning causes an operation to be terminated, channel 
control check, interface control check, or channel data 
check is indicated, depending on the condition. When 
an operation is terminated by program check, pro- 
tection check, or chaining check, the channel identifies 
the condition responsible for the termination and may 
or may not indicate incorrect length. When a data er- 
ror has been detected and the operation is terminated 
prematurely because of a program check, protection 
check, or chaining check, both data check and the pro- 
gramming error are identified. 

If the ccw fetched on command chaining contains 
the PCI flag but a programming error in the contents of 
the CCW or an unusual condition signaled by the de- 
vice precludes the initiation of the operation, the per 
bit appears in the csw associated with the interruption 
condition. Similarly, if device status or a programming 
error in the contents of the ccw causes the command 
to be rejected during execution of start i/o, the csw 
stored by start i/o contains the pci bit. However, 
when the channel detects a programming error in the 
CAW or in the first ccw, the pci bit may unpredictably 
appear in a csw stored by start i/o without the pci 
flag being on in the first ccw associated with the start 

I/O. 

Conditions detected by the channel are not related 
to those identified, by the i/o device. 

The following table summarizes the handling of 
status bits. The table lists the states and activities that 
can cause status indications to be created and the 
methods by which these indications can be placed in 
the csw. 
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WHEN 


WHEN 


UPON TERMINATION OF OPERATION 


DURING 


BY 


BY 


BY 


BY I/O 




l/OIS 


siJbchannel 


AT AT CONTROL AT 


COMMAND 


START 


TEST 


HALT 


INTER- 


STATUS 


IDLE 


WORKING 


SUBCHANNEL UNIT DEVICE 


CHAINING 


I/O 


I/O 


I/O 


RUPTION 



Attention 


C* 








c 


c* 


s 


s 




s 


Status modifier 










c 


c 


cs 


cs 


cs 


s 


Control unit end 








c« 






cs 


cs 


cs 


s 


Busy 












c 


cs 


cs 


cs 


s 


Channel end 






c* 


C«H 




c*t 


CfS 


s 




s 


Device end 


C* 








c* 


c t 


cts 


s 




s 


Unit check 






c 


c 


c 


c* 


cs 


cs 




cs 


Unit exception 






c 


c 


c 


c* 


cs 


s 




s 


Program-controlled interruption 




c* 


c 






c 


cs 


s 




s 


Incorrect length 




c 


c 










s 




s 


Program check 




c 


c 






c* 


cs 


s 




s 


Protection check 




c 


c 






c* 


cs 


s 




s 


Channel data check 




c 


c 










s 




s 


Channel control check 


c* 


c* 


c* 


c* 


c* 


c* 


cs 


cs 


cs 


cs 


Interface control check 


c« 


c« 


c* 


c« 


c* 


c* 


cs 


cs 


cs 


cs 


Chaining check 




c 


c 










s 




s 



NOTES 

C— The channel or the device can create or present the status 
condition at the indicated time. A CSW or its status portion is 
not necessarily stored at this time. 

Conditions such as channel end and device end are created at 
the indicated time. Other conditions may have been created 
previously, but are made accessible to the program only at the 
indicated time. Examples of such conditions are program check 
and channel data check, which are detected while data are 
transferred, but are made available to the program only with 
channel end, unless the PCI flag or equipment malfunctioning 
have caused an interruption condition to be generated earlier. 

S— The status indication is stored in the CSW at the indicated 
time. 

An S appearing alone indicates that the condition has been 
created previously. The letter C appearing with the S indicates 
that the status condition did not necessarily exist previously in 
the form that causes the program to be alerted, and may have 



been created by the I/O instruction or I/O interruption. For 
example, equipment malfunctioning may be detected during an 
I/O interruption, causing channel control check or interface 
control check to be indicated; or a device such as the 2702 
Transmission Control Unit may signal the control-unit-busy 
condition in response to interrogation by an I/O instruction, 
causing status modifier, busy, and control unit end to be indi- 
cated in the CSW. 
*— The status condition generates an interruption condition. 

Channel end and device end do not result in interruption 
conditions when command chaining is specified and no unusual 
conditions have been detected. 

f— This status indication can be created at the indicated time 
only by an immediate operation. 

H— When an operation on the selector channel has been termi- 
nated by HALT I/O, channel end indicates the termination of 
the data-handling portion of the operation at the control unit. 
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System Control Panel 



The system control panel contains the switches and 
lights necessary to operate and control the system. 
The system consists of the cpu, storage, channels, on- 
line control units, and i/o devices. Off-line control 
units and i/o devices, although part of the system 
environment, are not considered part of the system 
proper. 

System controls are divided into three sections: 
operator control, operator intervention, and customer 
engineering control. Customer engineering controls 
are also available on some storage, channel, and con- 
trol-unit frames. 

No provision is made for locking out any section of 
the system control panel. The conditions under which 
individual controls are active are described for each 



case. 



System Control Functions 

The main functions provided by the system control 
panel are the ability to reset the system; to store and 
display information in storage, in registers and in the 
psw; and to load initial program information. 

System Reset 

The system-reset function resets the cpu, the channels, 
and on-line, nonshared control units and i/o devices. 

The CPU is placed in the stopped state and all pend- 
ing interruptions are eliminated. The parity of general 
and floating-point registers, as well as the parity of the 
PSW, may be corrected. All error-status indicators are 
reset to zero. 

In general, the system is placed in such a state that 
processing can be initiated without the occurrence of 
machine checks, except those caused by subsequent 
machine malfunction. 

The reset state for a control unit or device is de- 
scribed in the appropriate System Reference Library 
(srl) publication. Off-line control units are not reset. 
A system-reset signal from a cpu resets only the 
functions in a shared control unit or device belonging 
to that CPU. Any function pertaining to another cpu 
remains undisturbed. 

The system-reset function is performed when the 
system-reset key is pressed, when initial program 



loading is initiated, or when a power-on sequence is 
performed. 

Programming Notes 

Because the system reset may occur in the middle of 
an operation, the contents of the psw and of result 
registers or storage locations are unpredictable. If the 
CPU is in the wait state when the system reset is per- 
formed, and i/o is not operating, this uncertainty is 
eliminated. 

Following a system reset, incorrect parity may exist 
in storage in all models and in the registers in some 
models. Since a machine check occurs when informa- 
tion with incorrect parity is used, the incorrect in- 
formation should be replaced, by loading new infor- 
mation. 

Store and Display 

The store-and-display function permits manual inter- 
vention in the progress of a program. The store-and- 
display function may be provided by a supervisor 
program in conjunction with proper i/o equipment 
and the interrupt key. 

In the absence of an appropriate supervisor pro- 
gram, the controls on the operator intervention panel 
permit the cpu to be placed in the stopped state, and 
subsequently to store and display information in main 
storage, in general and floating-point registers, and in 
the instruction-address part of the psw. The stopped 
state is achieved at the end of the current instruction 
when the stop key is pressed, when single instruction 
execution is specified, or when a preset address is 
reached. Once the desired intervention is completed, 
the CPU can be started again. 

The stopping and starting of the cpu in itself does 
not cause any alteration in program execution other 
than the time element involved (the transition from 
operating to stopped state is described under "Stopped 
State" in "Status Switching"). 

All basic store-and-display functions can be simu- 
lated by a supervisor program. 

Machine checks occurring during store-and-display 
functions do not interrupt or log immediately but may, 
in some cases, create a pending interruption. This 
interruption request can be removed by a system re- 
set. Otherwise, the interruption, when not masked off, 
is taken when the cpu is again in the operating state. 
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Initial Program Loading 

Initial program loading (ipl) is provided for the ini- 
tiation of processing when the contents of storage or 
the psw are not suitable for further processing. 

Initial program loading is initiated manually by se- 
lecting an input device with the load-unit switches 
and subsequently pressing the load key. When facili- 
ties for external system initialization are installed, 
initial program loading may be initiated externally by 
a signal received on one of the external-start lines. 

Pressing the load key causes a system reset, turns 
on the load light, turns oflF the manual light, sets the 
prefix trigger (if present), and subsequently initiates 
a read operation from the selected input device. 
When reading is completed satisfactorily, a new psw 
is obtained, the cpu starts operating, and the load 
light is turned oflF. 

When a signal is received on one of the external- 
start lines, the same sequence of events takes place, 
except that the read operation is omitted. 

System reset suspends all instruction processing, in- 
terruptions, and timer updating and also resets all 
channels, on-line nonshared control units, and i/o de- 
vices. The contents of general and floating-point regis- 
ters remain unchanged, except that the reset proce- 
dure may introduce incorrect parity. 

The prefix trigger is set after system reset. In man- 
ually initiated ipl, the trigger is set according to the 
state of the prefix-select key switch. When ipl is initi- 
ated by a signal on one of the two external-start lines, 
the trigger is set according to the identity of each line. 
The prefix trigger is part of the multisystem feature. 

Next, if IPL is initiated manually, the selected input 
device starts reading. The first 24 bytes read are placed 
in storage locations 0-23. Storage protection, pro- 
gram controlled interruption, and a possible incor- 
rect length indication are ignored. The double-word 
read into location 8 is used as the channel command 
word (ccw) for a subsequent i/o operation. When 
chaining is specified in this ccw, the operation pro- 
ceeds with the ccw in location 16, Either command 
chaining or data chaining may be specified. 

When the device provides channel end for the last 
operation of the chain, the i/o address is stored in bits 
21-31 of the first word in storage. Bits 16-20 are made 
zero. Bits 0-15 remain unchanged. The input operation 
and the storing of the i/o address are not performed 
when IPL is initiated by means of the external-start 
lines. 

The CPU subsequently fetches the double word in lo- 
cation as a new psw and proceeds under control of 
the new psw. The load light is turned ofi^. No i/o inter- 
ruption condition is generated. When the i/o opera- 



tions and PSW loading are not completed satisfactorily, 
the CPU idles, and the load light remains. 



Programming Notes 

Initial program loading resembles a stabt i/o that 
specifies the i/o device selected in the load-unit 
switches and a zero protection key. The ccw for this 
START i/o is simulated by cpu circuitry and contains a 
read command, zero data address, a byte count of 24, 
command-chain flag on, suppress-length-indication flag 
on, program-controlled-interruption flag off, chain- 
data flag off, and skip flag off. The ccw has a virtual 
address of zero. 

Initial program loading reads new information into 
the first six words of storage. Since the remainder of 
the IPL program may be placed in any desired section 
of storage, it is possible to preserve such areas of stor- 
age as the timer and psw locations, which may be 
helpful in program debugging. 

If the selected input device is a disk, the ipl infor- 
mation is read from track 0. 

The selected input device may be a channel-to- 
channel adapter involving two cpu's. After a system 
reset on this adapter, an attention signal is sent to the 
addressed cpu. That cpu then should issue the write 
command necessary to load a program into main stor- 
age of the requesting cpu. 

When the psw in location has bit 14 set to one, 
the CPU is in the wait state after the ipl procedure 
(the manual, the system, and the load lights are off, 
and the wait light is on). Interruptions that become 
pending during ipl are taken before instruction exe- 
cution. 



Operator Control Section 

This section of the system control panel contains only 
the controls required by the operator when the cpu 
is operating under full supervisor control. Under su- 
pervisor control, a minimum of direct manual inter- 
vention is required since the supervisor performs 
operations like store and display. 

The main functions provided by the operator con- 
trol section are the control and indication of power, 
the indication of system status, operator to machine 
communication, and initial program loading. 

The operator control section, with the exception of 
the emergency pull switch, may be duplicated once as 
a remote panel on a console. 

The following table lists all operator controls by 
the names on the panel or controls and describes 
their implementation. 
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NAME 


IMPLEMENTATION 


Emergency Pull 


Pull switch 


Power On 


Key, backlighted 


Power OflF 


Key 


Intenupt 


Key 


Wait 


Light 


Manual 


Light 


System 


Light 


Test 


Light 


Load 


Light 


Load Unit 


Three rotary switches 


Load 


Key 


Prefix Select* 


Key switch 


Multisystem feature 





Emergency Pull Switch 

Pulling this switch turns off all power beyond the 
power-entry terminal on every unit that is part of the 
system or that can be switched onto the system. There- 
fore, the switch controls the system proper and all 
off-line and shared control units and i/o devices. 

The switch latches in the out position and can be 
restored to its in position by maintenance personnel 
only. 

When the emergency pull switch is in the out po- 
sition, the power-on key is ineffective. 

Power-On Key 

This key is pressed to initiate the power-on sequence 
of the system. 

As part of the power-on sequence, a system reset is 
performed in such a manner that the system performs 
no instructions or i/o operations until explicitly di- 
rected. ITie contents of main storage are preserved. 

The power-on key is backlighted to indicate when 
the power-on sequence is completed. The key is ef- 
fective only when the emergency pull switch is in its 
in position. 

Power-OfF Key 

The power-off key is pressed to initiate the power-off 
sequence of the system. 

The contents of main storage (but not the keys in 
storage associated with the protection feature) are 
preserved, provided that the cpu is in the stopped 
state. The key is effective while power is on the system. 

Interrupt Key 

The interrupt key is pressed to request an external 
interruption. 

The interruption is taken when not masked off and 
when the cpu is not stopped. Otherwise, the inter- 
ruption request remains pending. Bit 25 in the inter- 
ruption-code portion of the current psw is made one 
to indicate that the interrupt key is the source of the 
external interruption. The key is effective while power 
is on the system. 



Walt Light 

The wait light is on when the cpu is in the wait state. 

Manual Light 

The manual light is on when the cpu is in the stopped 
state. Several of the manual controls are effective only 
when the cpu is stopped, that is, when the manual 
light is on. 

System Light 

The system light is on when the cpu cluster meter or 
customer-engineering meter is running. 

Programming Note 

The states indicated by the wait and manual lights 
are independent of each other; however, the state of 
the system light is not independent of the state of 
these two lights because of the definition of the run- 
ning condition for the meters. The following table 
shows possible conditions when power is on. 



SYSTEM 


MANUAL 


WAIT 


CPU 


I/O 


LIGHT 


LIGHT 


LIGHT 


STATE 


STATE 


off 


off 


off 


« 


« 


off 


off 


on 


Wait 


Not working 


off 


on 


off 


Stopped 


Not worldng 


off 


on 


on 


Stopped, 
wait 


Not working 


on 


off 


off 


Running 


Undetennined 


on 


off 


on 


Wait 


Working 


on 


on 


off 


Stopped 


Working 


on 


on 


on 


Stopped, 
wait 


Working 



* Abnormal condition 

Test Light 

The test light is on when a manual control is not in 
its normal position or when a maintenance function is 
being performed for cpu, channels, or storage. 

Any abnormal switch setting on the system control 
panel or on any separate maintenance panel for the 
CPU, storage, or channels that can affect the normal 
operation of a program causes the test light to be on. 

The test light may be on when one or more diag- 
nostic functions under control of diagnose are acti- 
vated or when certain abnormal circuit breaker or 
thermal conditions occur. 

The test light does not reflect the state of marginal 
voltage controls. 

Load Light 

The load light is on during initial program loading; 
it is turned on when the load key is pressed and is 
turned off after the loading of the new psw is com- 
pleted successfully. 

Load-Unit Switches 

Three rotary switches provide the 11 rightmost i/o 
address bits used for initial program loading. 
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The leftmost rotary switch has eight positions label- 
ed 0-7. The other two are 16-position rotary switches 
labeled with the hexadecimal characters 0-9, A-F. 

Load Key 

The load key is pressed to start initial program load- 
ing. The key is eflFective while power is on the system. 

Prefix-Select Key Switch 

The prefix-select key switch provides the choice be- 
tween main prefix and alternate prefix during manu- 
ally initiated initial program loading. 

The setting of the switch determines the state of the 
prefix trigger following the system reset after the load 
key is pressed. 

The switch is part of the multisystem feature. 



Operator Intervention Section 

This section of the system control panel contains the 
controls required for the operator to intervene in nor- 
mal programmed operation. These controls may be 
intermixed with the customer engineering controls, 
and additional switch positions and nomenclature may 
be included, depending on the model. 

Operator intervention provides the system-reset and 
the store-and-display functions. Compatibility in per- 
forming these functions is maintained, except that the 
word size used for store and display depends on the 
physical word size of storage for the model. Switches 
for display of the instruction address are absent on 
models that continuously display the instruction ad- 
dress. 

The following table lists all intervention controls by 
the names on the panel or controls and describes their 
implementation. 



NAME 


IMPLEMENTATION 


System Reset 


Key 


Stop 


Key 


R^te 


Rotary switch 


Start 


Key 


Storage Select 


Rotary or key switch 


Address 


Rotary or key switches 


Data 


Rotary or key switches 


Store 


Key 


Display 


Key 


SetIC 


Key 


Address Compare 


Rotary or key switches 


Alternate Prefix* 


Light 


Multisystem feature 





System -Reset Key 

The system-reset key is pressed to cause a system re- 
set; it is efi^ective while power is on the system. The 
reset function does not affect any off-line or shared 
device. 



Stop Key 

The stop key is pressed to cause the cpu to enter the 
stopped state. The key is effective while power is on 
the system. 

Programming Note 

Pressing the stop key has no effect when a continuous 
string of interruptions is performed or when the cpu 
is unable to complete an instruction because of ma- 
chine malfunction. The effect of pressing the key is 
indicated by the turn-on of the manual light as the 
CPU enters the stopped state. 

Rate Switch 

This rotary switch indicates the manner in which in- 
structions are to be performed. 

The switch has two or more positions, depending 
on model. The vertical position is marked process. In 
this position, the system starts operating at normal 
speed when the start key is pressed. The position 
left of vertical is marked instruction step. When the 
start key is pressed with the rate switch in this po- 
sition, one complete instruction is performed, and all 
pending, not masked interruptions are subsequently 
taken. The cpu next returns to the stopped state. 

Any instruction can be executed with the rate 
switch set to instruction step. Input/output opera- 
tions are completed to the interruption point. When 
the CPU is in the wait state, no instruction is per- 
formed, but pending interruptions, if any, are taken 
before the cpu returns to the stopped state. Initial 
program loading is completed with the loading of the 
new psw before any instruction is performed. The 
timer is not updated while the rate switch is set to 
instruction step. 

The test light is on when the rate switch is not set 
to process. 

The position of the rate switch should be changed 
only while the cpu is in the stopped state. Otherwise 
unpredictable results occur. 

Start Key 

The start key is pressed to start instruction execution 
in the manner defined by the rate switch. 

Pressing the start key after a normal stop causes in- 
struction processing to continue as if no stop had oc- 
curred, provided that the rate switch is in the process 
or instruction-step position. Pressing the start key 
after system reset without first introducing a new in- 
struction address yields unpredictable results. 

The key is effective only while the cpu is in the 
stopped state. 
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Storage-Select Switch 

The storage area to be addressed by the address 
switches is selected by the storage-select switches. 

The switch can select main storage, the general reg- 
isters, the floating-point registers and, in some cases, 
the instruction-address part of the psw. 

When the general or floating-point registers are not 
addressed directly but must be addressed by using 
another address such as a local-store location, infor- 
mation is included on the panel to enable an operator 
to compute the required address. 

The switch can be manipulated without disrupting 
CPU operations. 

Address Switches 

The address switches address a location in a storage 
area and can be manipulated without disrupting cpu 
operation. The address switches, with the storage-se- 
lect switch, permit access to any addressable location. 
Correct address parity is generated. 

Data Switches 

The data switches specify the data to be stored in the 
location specified by the storage-select switch and ad- 
dress switches. 

The number of data switches is sufficient to allow 
storing of a full physical storage word. Correct data 
parity is generated. Some models generate either cor- 
rect or incorrect parity under switch control. 

Store Key 

The store key is pressed to store information in the 
location specified by the storage-select switch and ad- 
dress switches. 

The contents of the data switches are placed in the 
main storage, general register, or floating-point regis- 
ter location specified. Storage protection is ignored. 
When the location designated by the address switches 
and storage-select switch is not available, data are not 
stored. 

The key is effective only while the cpu is in the 
stopped state. 

Display Key 

The display key is pressed to display information in 
the location specified by the storage-select switch and 
address switches. 

The data in the main storage, general register, or 
floating point register location, or in the instruction- 
address part of the psw specified by the address 
switches and the storage-select switch, are displayed. 



When the designated location is not avaflable, the dis- 
played information is unpredictable. In some models, 
the current instruction address is continuously dis- 
played and hence is not explicitly selected. 

The key is effective only while the CPU is in the 
stopped state. 

Set IC Key 

This key is pressed to enter an address into the in- 
struction-address part of the current psw. 

The address in the address switches is entered in 
bits 40-63 of the current psw. In some models the ad- 
dress is obtained from the data switches. 

The key is effective only while the cpu is in the 
stopped state. 

Address-Compare Switch 

These rotary or key switches provide a means of stop- 
ping the CPU on a successful address comparison. 

When these switches are set to the stop position, 
the address in the address switches is compared 
against the value of the instruction address on all 
models and against all addresses on some models. A 
match causes the cpu to enter the stopped state. Com- 
parison includes only the part of the instruction ad- 
dress that addresses the physical word size of storage. 

Comparison of the entire halfword instruction ad- 
dress is provided in some models, as is the ability to 
compare data addresses. 

The address-compare switches can be manipulated 
without disrupting cpu operation other than by caus- 
ing the address-comparison stop. When they are set 
to any position except normal, the test light is on. 

Programming Note 

When an address not used in the program is sel(3cted 
in the address switches, the cpu runs as if the address- 
compare switches were set to normal, except for the 
reduction in performance which may be caused by the 
address comparison. 

Alternate-Prefix Light 

The alternate-prefix light is on when the prefix trigger 
is in its alternate state. The light is part of the multi- 
system feature. 



Customer Engineering Section 

This section of the system control panel contains con- 
trols intended only for customer-engineering use. 
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Appendix A. Instruction Use Examples 



The following examples illustrate the use of many 
System/360 instructions. Before studying one of these 
examples, the reader should first consult the instruction 
description in this manual for the particular instruc- 
tion of interest to him. Note that each instruction 
description contains the System/360 assembly lan- 
guage mnemonic op code and symbolic operand desig- 
nation as well as the machine instruction format. 

For clarity and for ease in programming, each ex- 
ample in this section presents the instruction both as 
it is written in an assembly-language statement and as 
it appears when assembled in storage (hexadecimal 
machine format). As a rule, all numerical operands 
are written in hexadecimal format unless otherwise 
specified. Hexadecimal operands are shown converted 
into binary and/or decimal if such conversion helps to 
clarify the example for the reader. Storage addresses 
are also given in hexadecimal. In the assembly-lan- 
guage statements, registers, lengths, and masks are all 
presented in decimal, but displacements may be in 
hexadecimal or decimal. A hexadecimal displacement 
is indicated by X 'a number', where the number can 
range from ooo-fffi6. Immediate operands are nor- 
mally shown in hexadecimal. Whenever the value in 
a register or storage location is referred to as "not sig- 
nificant," this value is replaced during the execution 
of the instruction. 

When writing ss format instructions in System/360 
assembly language, lengths are given as the total 
number of bytes in the field. This differs from the 
machine definition regarding lengths which states that 
the length is the number of bytes to be added to the 
field address to obtain the address of the last byte of 
the field. Thus the machine length is one less than the 
assembly-language length. The assembly program 
automatically subtracts one from the length specified 
when the instruction is assembled. 



Branching 

Branch On Condition (BC, BCR) 

The BRANCH ON CONDITION instructions test the condi- 
tion code to see whether a branch should or sliould 
not be taken. The branch is taken only if the condition 
code is as specified by a mask. 



MASK 


CONDITION 


VALUE 


CODE 


8 





4 


1 


2 


2 


1 


3 



For example, assume that an add (a, ar) operation 

has been performed and that you wish to branch to 

address 6050 if the sum is zero or less ( condition code 

= or 1). Also assume: 

Register 10 contains 00 00 50 00 
Register 11 contains 00 00 10 00 

The Rx form of the instruction performs the re- 
quired test (and branch, if necessary) when written 
as: 

Machine Format Assembler Format 

OP CODE Ml X2 B2 D2 OP CODE Ml D2 X2 B2 

47 I C I B I A I 050 ] ~BC 12,X'50'( 11,10) 

A mask of 15 indicates a branch on any condition 
(an unconditional branch). A mask of zero indicates 
that no branch is to occur (a no-operation). 

Branch and Link (BAL, BALR) 

The BRANCH AND LINK instructions are commonly used 
to branch to a subroutine with the option of later re- 
turning to the main instruction sequence. For example, 
assume that you wish to branch to a subroutine at 
storage address 1160. Also assume: 

The contents of register 2 are not significant 

Register 5 contains 00 00 11 50 

There is a BAL instruction at address 00 00 C6 

(PSW bits 40-63 will contain 00 00 CA after 
execution of BAL) 

The format of the bal instruction is : 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE Rl D2 X2B2 

BAL 2,X'10'(^0,5) 



45 


2 





5 


010 



After the instruction is executed: 

Register 2 (bits 8-31) contains 00 00 CA 
PSW bits 40-63 contain 00 11 60 

The programmer can return to the main instruction 
sequence at any time with a branch on condition 
(bcr) instruction that specifies register 2 and a mask 
of 15io, provided that register 2 has not meanwhile 
been disturbed. 

The BALR instruction with the R2 field equal to zero 
may be used to load a register for use as a base 
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register. For example, in the assembly language, the 

sequence of statements: 

BALR 15, 

USING *, 15 

tells the assembly program that register 15 is to be 
used as the base register in assembling this program 
segment and that when the program is executed, the 
address of the next sequential instruction following 
the BAiJi will be placed in the register. (The using 
statement is an "assembler instruction" and is thus 
not a part of the object program. ) 

At any time the condition code may be preserved 
for future inspection with balr Ri,o. Bits 2 and 3 of 
the register (Ri) contain the condition code. 



Branch On Count (BCT, BCTR) 

The BRANCH ON COUNT instructions are often used to 
execute a program loop for a specified number of 
times. For example, assume that the following repre- 
sents some lines of coding in an assembly language 
program: 



LUPE 



BACK 



AR 



8,1 



BCT 6,LUPE 



where register 6 contains 00 00 00 03 and the address 

of LUPE is 6826. Also assume that register 10 contains 

00 00 68 00. 

The format of the bct instruction is: 

Machine Format Assembler Format 

(alternate form to above) 

X2 B2 D2 OP CODE Rl D2 X2 B2 

BCT 6,X'26'(0,10) 



Hi 



46 1 6 





A 


026 



The effect of the coding shown above is to execute 
three times the loop defined by locations lupe and 
back. 



The format of the instruction is: 
Machine Format 

OP CODE Rl R3 32 D2 

ooo"] 



86 



6 



Assembler Format 

OPCODE RlR3t>2B2 

BXH 4^,0(10) 



When the instruction is executed, first the contents 

of register 6 are added to register 4, second the sum is 

compared with the contents of register 7, and third the 

decision to branch or not to branch is made. After 

execution: 

Register 4 contains 00 00 00 8C == 140io 
Registers 6 and 7 are unchanged 

Since the new value in register 4 is not greater than 
the value in register 7, the branch to address 7130 is 
not taken. 

When the register used to contain the increment is 
odd, that register also becomes the comparand register. 
The following assembly-language subroutine illustrates 
how this feature may be used to search a table. 
Table 



ARGl 


FUNCTl 


ARG2 


FUNCT2 


ARG3 


FUNCT3 


ARG4 


FUNCT4 


ARCS 


FUNCT5 


ARG6 


FUNCT6 



2 bytes 
Assume that: 



2 bytes 



Register contains the search argument 

Register 1 contains the width of tlie table in bytes (00 00 00 04) 

Register 2 contains the length of the table in bytes (00 00 00 18) 

Register 3 contains the starting address of the table 

Register 14 contains the return address in the main program 

As the following subroutine is executed, the argu- 
ment in register is successively compared with the 
arguments in the table. If an equality is found, the cor- 
responding function replaces the argument in register 
0. If an equality is not found, ffib replaces the argu- 
ment in register 0. 



SEARCH 

NOTEQUAL 

NOTFOUND 

LOOP 



LNR 

BXH 

LA 

BCR 

CH 

BC 

LH 

BCR 



1,1 

2,l,LOOP 

0,X'FF' 

15,14 

0,0(2,3) 

7,NOTEQUAL 

0,2(2,3) 

15,14 



Branch On Index High (BXH) 

The BRANCH ON INDEX HIGH instruction is an index-in- 
crementing and loop-controlling instruction that causes 
a branch whenever the sum of an index value and an 
increment value is greater than some comparand. For 
example, assume that: 

Register 4 contains 00 00 00 8A = 138io = the index 
Register 6 contains 00 00 00 02 = 2io = the increment 
Register 7 contains 00 00 00 AA = 170io = the comparand 
Register 10 contains 00 00 71 30 = the branch address 



Branch On Index Low or Equal (BXLE) 
This instruction is similar to branch on index high 
except that the branch is successful when the sum is 
low or equal compared to the comparand. 

Execute (EX) 

The EXECUTE instruction causes one instruction in main 
storage to be executed out of sequence without actual- 
ly branching to the object instruction. For example, as- 
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sume that a move (si) instruction is located at address 
3820, with format as follows: 

Assembler Format 

OPCODE Dl Bl 12 



Machine Format 

OP CODE 12 Bl Dl 



92 


66 


C 


003 



MVI 3(12),X'66' 
7 8 1516 1920 31 

where register 12 contains 00 00 89 16. 
Further assume that at storage address 5000, the 



following EXECUTE instruction is located: 

Assembler Format 

OP CODE R1D2X2 B2 



Machine Format 

OPCODE Rl X2 B2 



D2 



44 


1 





A 


000 



7 8 



31 



EX 1,0(0,10) 



11 12 1516 1920 

where register 10 contains 00 00 38 20, and register 1 
contains 00 OF FO 99. 

When the instruction at 5000 is executed, bits 24-31 
of register 1 are OR'ed inside the cpu with bits 8-15 of 
the instruction at 3820: 



Bits 8-15: 
Bits 24-31: 



0110 OIIO2 = 66 
1001 IOOI2 = 99 



Machine Format 

OP CODE 12 Bl 



Dl 



92 


FF 


C 


003 



Result: 1111 IIII2 = FF 

causing the instruction at 3820 to be executed as if it 

originally were: 

Assembler Format 
OP CODE Dl Bl 12 
MVI 3(12),X'FF' 

7 8 15 16 1920 31 

However, after execution: 

Register 1 is unchanged 

The instruction at 3820 is unchanged 

Storage location 8919 contains FF 

The CPU next executes the instruction at address 5004 

(PSW bits 40-63 contain 00 50 04) 

Fixed'Point Arithmetic 

Load (L, LR) 

The LOAD instructions place, unchanged, the contents 
of a word in storage or of a register into another regis- 
ter. For example, assume that the four bytes starting 
with location 21004 (a full- word boundary) are to be 
loaded into register 10. Initially: 

Register 5 contains 00 02 00 00 

Register 6 contains 00 00 10 04 

The contents of register 10 are not significant 

Storage locations 21004-21007 contain 00 00 AB CD 

To load register 10, the rx form of the instruction 
can be used: 

Machine Format 

OPCODE Rl X2 B2 



D2 



58 


A 


5 


6 


000 



Assembler Format 

OPCODE R1D2X2B2 

L 10,0(5,6) 

After the instruction is executed, register 10 contains 
00 00 AB CD. 

Load Halfword (LH) 

The LOAD HALFWORD instruction places unchanged the 

contents of a halfword in storage into the right half of 



a register. The left half of the register is replaced by 

zeros or ones to reflect the sign (leftmost bit) of the 

halfword. 

For example, assume that the two bytes in storage 

locations 1802-1803 are to be loaded into register 6. 

Also assume: 

Register 6 contains 7F 12 34 56 
Register 14 contains 00 00 18 02 
Locations 1802-1803 contain 00 20 

The instruction required to load the register is: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE R1D2X2 B2 



48 


6 





E 


000 



LH 6,0(0,14) 



After the instruction is executed, register 6 contains 
00 00 00 20. If 1802-1803 contained a negative number, 
for example A7 B6, the sign bit would again be prop- 
agated to the left, giving FF FF A7 B6 as the final 
result in register 6. 

Add Halfword (AH) 

The ADD HALFWORD instruction algebraically adds the 
halfword contents of a storage location to the contents 
of a register. The halfword storage operand is ex- 
panded to 32 bits after it is fetched and before it is 
used in the add operation. The expansion consists of 
propagating the leftmost ( sign ) bit 16 positions to the 
left. For example, assume that the contents of storage 
locations 2000-2001 are to be added to register 5. 
Initially: 

Register 5 contains 00 00 00 19 = 25io 

Storage locations 2000-2001 contain FF FE = -2io 

Register 12 contains 00 00 18 00 

Register 13 contains 00 00 01 50 

The format of the required instruction is: 

Machine Format Assembler Format 

OPCODE Rl X2 B2 D2 OPCODE Rl D2 X2 B2 

4A I 5 I D I C I 6B0| AH 5,X'6B0'(i3Ti2y 

After the instruction is executed, register 5 contains 
00 00 00 17 = 23io 

Compare Halfword (CH) 

The COMPARE HALFWORD instruction compares a half- 
word in storage with the contents of a register. For ex- 
ample, assume that: 

Register 4 contains FF FF 80 00 = -32,768io 

Register 13 contains 00 01 60 50 

Storage locations 16080-16081 contain 8000 = -32,768io 

When the instruction: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE Rl D2 X2 B2 

49 I 4 I I D 03FI CH 4,X'30'(0,13) 

is executed, the contents of locations 16080-16081 are 
fetched, expanded to 32 bits (the sign bit is prop- 
agated to the left ) , and compared with the contents 
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of register 4. Because the two numbers are equal, the 
condition code is set to 0. 



Multiply (M, MR) 

Assume that a number in register 5 is to be multiplied 

by the contents of a word at address 3750. Initially: 

The contents of register 4 are not significant 

Register 5 contains 00 00 00 9A = l54io = the multiplicand 

Register 11 contains 00 00 30 00 

Register 12 contains 00 00 06 00 

Storage locations 3750-3753 contain 00 00 00 83 = 

131 10 = the multiplier 

The instruction required to perform the multiplica- 
tion is: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE Rl D2 X2 B2 

5C I 4 I B I C I 150 I M 4,X'150'( 11,12) 

After the instruction is executed: 

Register 4 contains 00 00 00 00 | , 

Register 5 contains 00 00 4E CE =3 20,174ioJ P™'^"*^^ 
Storage locations 3750-3753 are unchanged 

The RR format of the instruction can be used to 
square a number in a register^jAssume that register 7 
contains 00 00 00 10 = I610. Tlie instruction: 

Machine Format Assembler Format 

OP CODE Rl R2 OP CODE RIR2 

IC I 6 I 7 I MR 6J 

multiplies the number in register 7 by itself. The prod- 
uct, 00 0000000000 0100=: 256io, appears in reg- 
isters 6 and 7. 



age. Since the dividend is assumed to be 64 bits long, 

it is important that the proper sign is first affixed. For 

example, assume that: 

Storage locations 3550-3553 contain 00 00 08 D7 = 

2270io = the dividend 
Storage locations 3554-3557 contain 00 00 00 32 = 

50io = the divisor 
Register 6 does not contain all zeros 
The initial contents of register 7 are not significant 
Register 8 contains 00 00 35 50 

The following assembly language statements load 
the registers properly and perform the divide opera- 
tion: 

COMMENTS 

L 6,0(0,8) Places 00 00 08 D7 into 

register 6. 

SRD A 6,32 ( ) Shifts 00 00 08 D7 into 

register 7. Register 6 is filled 
with zeros (sign bits). 

D 6,4(0,8) Performs the division. 

The machine format of the above divide instruction 
is: 



OP CODE 


Rl 


X2 


B2 


D2 


5D 


6 





8 


004 



After all the above instructions are executed: 

Register 6 contains 00 00 00 14 = 20io = the remainder 
Register 7 contains 00 00 00 2D == 45io = the quotient 

Note that if the dividend had not been first placed 
in register 6 and shifted into register 7, register 6 
would not have been filled with the proper sign bits 
(zeros in this example) and the divide instruction 
would not have given the expected results. 



Multiply Halfword (MH) 

The MULTIPLY HALFWORD iustructiou is used to multi- 
ply a registei" by a halfword in storage. For example, 
assume that: 

Register 11 contains 00 00 00 15 == 21 lo = the multipUcand 

Register 14 contains 00 00 01 00 ^ 

Register 15 contains 00 00 20 00 

Storage locations 2102-2103 contain FF D9 = -39io = 

the multiplier 

The instruction: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE Rl D2 X2 B2 

MH 11,2(14,15) 



4G 



B 



E 



002 



multiplies the two numbers. The product, ff ff fc cd 
= —819x0, replaces the original contents of register 11. 
Only the low-order 32 bits of a product are stored in 
a register; any higher-order bits are lost. No program 
interruption occurs upon overflow. 

Divide (D, DR) 

The DivroE instruction divides a dividend in an even/ 
odd register pair by a divisor in a register or in stor- 



Convert to Binary (CVB) 

The CONVERT TO BINARY iustructiou converts an eight- 
byte, signed, packed-decimal number into a signed 
binary number and loads the result into a general reg- 
ister. After the conversion operation is completed, the 
number is in the proper form for use as an operand in 
fixed-point arithmetic. For example, assume: 

Storage locations 7608-760F contain 00 00 00 00 00 25 59 4C, 

a positive packed-decimal number 
The contents of register 7 are not significant 
Register 13 contains 00 00 76 00 

The format of the conversion instruction is: 

Machine Format Assembler Format 

OP CODE R1DJ1X2 B2 

CVB 73(0,13) 

After the instruction is executed, register 7 contains 
00 00 63FA = + 25, 594io. 

Convert to Decimal (CVD) 

The CONVERT TO DECIMAL instruction performs func- 
tions exactly opposite to those of the convert to bi- 
nary instruction, cvd converts a binary number in a 



OP CODE 


Rl 


X2 


B2 


D2 


4F 


7 





D 


008 
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register to packed decimal and stores the result in a 

double word. For example, assume: 

Register 1 contains 00 00 OF OF = 3855io 
Register 13 contains 00 00 76 00 
PSW bit 12 = (EBCDIC mode) 

The format of the conversion instruction is: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE R1D2X2 B2 

4E I 1 I I D I 008 I CVD 1,8(0,13) 

After the instruction is executed, location 7608-760F 
contain 00 00 00 00 00 03 85 5+. The plus sign gen- 
erated is the standard ebcdic plus sign, IIOO2. 

Shift Left Single (SLA) 

Because the sign bit remains unchanged during an sla 

operation, this instruction performs an algebraic shift. 

For example, if the contents of register 2 are: 

00 7F OA 72 = 0000 0000 0111 1111 0000 1010 0111 OOIO2 

the instruction: 

Machine Format Assembler Format 

OPCODE Rl R3 B2 D2 OPCODE R1D2B2 

8B I 2 |g^ I 008 I SLA 2,8(0) 

results in register 2 being shifted left 8 places so that 

its new contents are: 

7F OA 72 00 = 0111 1111 0000 1010 0111 0010 0000 OOOO2 

If a left shift of 9 places had been specified, a signi- 
ficant bit would have been shifted out of position 1, 
and a fixed-point overflow interruption might have 
occurred (unless Psw bit 36 equaled 0). 

Note that register does not participate in the op- 
eration and that the contents of the R3 field are ig- 
nored. 

Shift Left Double (SLDA) 

The SHIFT LEFT DOUBLE iustruction is similar to shift 
LEFT SINGLE cxccpt that SLDA shifts the 63 bits (not in- 
cluding the sign ) of an even/odd register pair. The Ri 
field of this instruction must be even. For example, if 
the contents of registers 2 and 3 are: 
00 7F OA 72 FE DC BA 98 = 

0000 0000 0111 1111 0000 1010 0111 0010 nil iiio iioi 

1100 1011 1010 1001 IOOO2 
the instruction: 

Machine Format Assembler Format 

OPCODE Rl R3 B2 D2 OPCODE RID2 B2 



Store Multiple (STM) 

Assume that the contents of general registers 14, 15, 0, 

and 1 are to be stored in consecutive words starting 

with storage location 4050 and that: 

Register 14 contains 00 00 25 63 

Register 15 contains 00 01 27 36 

Register contains 12 43 00 62 

Register 1 contains 73 26 12 57 

Register 6 contains 00 00 40 00 

The initial contents of locations 4050-405F are not significant 

The STORE MULTIPLE instruction allows the use of 
just one instruction to store the contents of the four 
registers when it is written as: 

Machine Format Assembler Format 

OP CODE Rl R3 B2 D2 OP CODE Rl R3 D2 B2 

STM 14,1,X'50'(6) 



90 


E 


1 


6 


050 



After the instruction is executed: 

Locations 4050-4053 contain 00 00 25 63 
Locations 4054-4057 contain 00 01 27 36 
Locations 4058-405B contain 12 43 00 62 
Locations 405C-405F contain 73 26 12 57 



Logical Operations 
Move (MVI, MVC) 

Move Immediate (MVI) 

The MOVE IMMEDIATE instruction can place one byte of 
information from the instruction stream into any des- 
ignated location in storage. For example, if the in- 
struction: 

Machine Format Assembler Format 

OP CODE 12 Bl Dl OP CODE Dl Bl 12 

92 I FA I I 055] MVI 85(0),X'FA' 

is executed, bits 8-15 of the instruction (1111 IOIO2) 
are copied in storage location 85io. 



Move Characters (MVC) 

The MVC instruction can be used to move a data field 
from one location in storage to another. For example, 
assume that the following two fields are in storage: 



8F 


2 


m. 





OIF 



SLDA 2,31(0) pi^i^ I I CI I C2 I C3 I C4 I C5 I C6 I C7 I C8 I C9 I CA I CB 



results in registers 2 and 3 both being left-shifted 31 

places, so that their new contents are: 

7F 6E 5D 4C 00 00 00 00 = 

0111 1111 0110 1110 0101 1101 0100 1100 0000 0000 0000 

0000 0000 0000 0000 OOOO2 

In this case, a significant bit is shifted out of position 
1, and a fixed-point overflow interruption occurs (un- 
less PSW bit 36 equals 0). 



3840 3848 

Field 2 I Fl I F2 I F3 I F4 | F5 | F6 | F7 | F8 |"F9]' 

Also assume: 

Register 1 contains 00 00 20 48 
Register 2 contains 00 00 38 40 

With the following instruction the first eight bytes 
of field 2 replace the first eight bytes of field 1: 
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OP CODE 



Machine Format 

X. Bl Dl 



B2 



D2 



D2 



07 



000 



000 



Assembler Format 

OP CODE Dl L Bl D2 B2 

~MVC 0(8 J) ,0(2) 
After the instruction is executed, field 1 becomes: 

2048 2052 

Field 1 [ITT F2j F3~| F4 | F5 | ^6 [ F7 | F8 | C9 [ CA | "CB~| 

Field 2 is unchanged. 

As indicated in the programming note in the move 
instruction description, mvc can be used to propagate 
one character through a field by starting the first 
operand field one byte to the right of the second oper- 
and field. For example, suppose that an area in storage 
starting with address 358 contains the following data: 



358 
















360 


1 00 1 


|F1 


|F2 


|F3 


|F4| 


F5 


F6 


|F7 


F8| 



With the following mvc instruction, the zeros in 
location 358 can be propagated throughout the entire 
field (assume that register 11 contains 00 00 03 58) : 
Machine Format 

OPCODE L Bl Dl B2 D2 



D2 



07 B 001 B 000 



Assembler Format 

OP CODE Dl L Bl D2 B2 

MVC i(8;n),o(ii) 

Because the mvc handles one byte at a time, the 
above instruction essentially takes the byte at address 
358 and stores it at 359 (359 now contains 00), takes 
the byte at 359 and stores it at 35A, etc., until the 
entire field is filled with zeros. Note that an mvi in- 
struction could have originally been used to place the 
byte of zeros in location 358. 

Notes: 

1. Although the field occupying locations 358-360 
contains nine bytes, the length coded in the assembler 
format is equal to the number of moves ( one less than 
the field length). 

2. The order of operands is important even though 
only one field is involved. 



Move Numerics (MVN) 

To illustrate the operation of the move numerics in- 
struction, assume that the following two fields are in 
storage: 

7090 7087 



Field 1 


1 CI 


1 C2 1 C3 1 C4 1 C5 1 C6 1 C7 1 C8 1 




7041 


7049 


Field 2 


1 FO 1 


1 Fl 1 F2 F3 1 F4 1 F5 1 F6 1 F7 1 F8 1 



Also assume: 

Register 14 contains 00 00 70 90 
Register 15 contains 00 00 70 40 

After the instruction: 
Machine Format 



OP CODE 


L 


Bl 


Dl 


B2 


D2 


Dl 


03 


F 


001 


E 


000 



Assembler Format 

OP CODE Dl L Bi D2 B2 

^VN 1(4,15), 0(14) 
is executed, field 2 becomes: 



7041 












7049 


1 Fl 1 F2 1 


1 F3 


1 F4 


1 F4 1 


1 F5 


1 F6 j 


I F7 1 F8 1 



The numeric portions of locations 7090-7093 have 
been stored in the numeric portions of locations 7041- 
7044. The contents of locations 7090-7097 and 7045- 
7049 are unchanged. 



Move Zones (MVZ) 

The MOVE ZONES instruction, similar to mvc and mvn, 
can operate on overlapping or nonoverlapping fields. 
( See the examples for mvc and mvn. ) When operating 
on nonoverlapping fields, mvz works similar to the mvn 
instruction in the previous example, except that the 
mvz moves the high-order four bits of each byte. To 
illustrate the use of mvz with overlapping fields, as- 
sume that the following data field is in storage: 



800 










805 


|F1 


|C2| 


1 F3 


|C4| 


1 F5 


|C6| 



Also assume that register 15 contains 00 00 08 00. 
The instruction: 

Machirte Format 

OP CODE L Bl Dl B2 D2 



D3 



04 



001 



000 



Assembler Format 

OPCODE DIL Bl D2 B2 

MVZ 1(5,15),0(15) 

propagates the zone from the byte at address 800 
through the data field, so that the field becomes: 



800 



805 



Fl I F2 I F3 I F4 I F5 I F6 



Compare Logical (CL, CLR, CLi, CLC) 

The COMPABE LOGICAL instructions differ from the alge- 
braic compare instructions (c, cr) in that all quanti- 
ties are handled as if unsigned. 
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Compare Logical Registers (CLR) 
Assume that: 

Register 1 contains 00 00 00 01 
Register 2 contains FF FF FF FF 

Execution of the instruction: 

Machine Format Assembler Format 

OP CODE Rl R2 OP CODE R1R2 

15 I 1 2 I CLR 1^ 

sets the condition code to 1. A condition code of 1 in- 
dicates that the first operand is lower than the second. 
However, if an algebraic compare instruction had been 
executed, the condition code would have been set to 2, 
indicating that the first operand is higher. During alge- 
braic comparison, the contents of register 1 are inter- 
preted as -j-l and the contents of register 2 as —1. 
During logical comparison, the leftmost byte of reg- 
ister 2 is compared with the leftmost byte of register 1; 
each byte is interpreted as a binary number. In this 
case: 

Leftmost byte of register 1: 0000 OOOO2 = Oio 
Leftmost byte of register 2: 1111 IIII2 = 255io 

If the two leftmost bytes are equal, the next two 
bytes will be compared, etc., until either an inequality 
is discovered or the contents of the registers are ex- 
hausted. 

Compare Logical Immediate (CLI) 

The CLI instruction logically compares a byte from the 
instruction stream with a byte from storage. For ex- 
ample, assume that: 
Register 10 contains 00 00 17 00 
Storage location 1703 contains 7E 

Execution of the instruction: 

Machine Format Assembler Format 

OP CODE 12 Bl Dl OP CODE Dl Bl 12 

95 I AF I A I 003| CLI 3(10),X'AF' 

sets the condition code to 1, indicating that the first 
operand (the quantity in main storage) is lower than 
the second (immediate) operand. 

Compare Logical Characters (CLC) 

The COMPARE LOGICAL CHARACTTERS instruction can be 
used to perform the logical comparison of storage fields 
up to 256 bytes in length. For example, assume that 
the following two fields of data are in storage: 
Field 1 



Execution of the instruction: 
Machine Format 

OP CODE L Bl Dl B2 D2 



D5 


OB 


6 


006 


7 


000 



Assembler Format 

OP CODE Dl L Bl D2 B2 

CLC 6(12,6),0(7) 
sets the condition code to 1, indicating that field 1 is 
lower than field 2. 

Because clc compares bytes on an unsigned binary 
basis, the instruction can be used to collate fields com- 
posed of characters from the ebcdic code. For example, 
in EBCDIC, the above two data fields are: 

Field 1 JOHNSON,A.B. 
Field 2 JOHNSON,A.C. 

The condition code of 1 tells us that A. B. Johnson 
precedes A. C. Johnson, thus placing the names in the 
correct alphabetic order. 



AND (N, NR, Nl, NC) 

When the Boolean operator and is applied to two bits, 
the result is 1 when both bits are 1; otherwise, the re- 
sult is 0. When two bytes are ANn'ed in System/360, 
each pair of bits is handled separately; there is no con- 
nection from one bit position to another. 



AND (Nl) 

A frequent use of the and instruction is to set a partic- 
ular bit to zero. For example, assume that storage loca- 
tion 4891 contains 0100 OOII2. To set the eighth (right- 
most ) bit of this byte to without affecting the other 
bits, the following instruction can be used (assume 
that register 8 contains 00 00 48 90): 

Machine Format Assembler Format 

OP CODE 12 Bl Dl OP CODE Dl Bl 12 



94 


FE 


8 


001 



NX 1(8),X'FE' 

When this instruction is executed, the byte in stor- 
age is AND'ed with the immediate byte: 



Location 4891: 
Immediate byte: 



0100 00112 
1111 IIIO2 



Result: 0100 00102 

The resulting byte with bit seven set to is stored in 

location 4891. The condition code is set to 1. 



Dl I D6 I C8 I D5 I E2 I D6 I D5 I 6B I CI I 4B I C2 I 4B 



Field 2 

1900 



190B 



I Dl I D6 I C8 I D5 I E2 I D6 I D5 I 6B I CI I 4B I C3 I 4B 

Also assume: 

Register 6 contains 00 00 18 80 
I Register 7 contains 00 00 19 00. 



OR (O, OR, Ol, OC) 

When the Boolean operator or is applied to two bits, 
the result is 1 when either bit is 1; otherwise, the re- 
sult is 0. When two bytes are OR'ed in System/360, 
each pair of bits is handled separately; there is no 
connection from one bit position to another. 
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OR (Ol) 

A frequent use of the or instruction is to set a par- 
ticular bit to 1. For example, assume that storage loca- 
tion 4891 contains 0100 OOIO2. To set the eighth (right- 
most) bit of this byte to 1 without affecting the other 
bits, the following instruction can be used (assume 
that register 8 contains 00 00 48 90): 

Machine Format Assembler Format 

OP CODE 12 Bl Dl OP CODE Dl Bl 12 

[ 



96 



01 



001 



OI l(8),X'0r 

When this instruction is executed, the byte in stor- 
age is OR'ed with the immediate byte: 



Location 4891: 
Immediate byte: 



0100 OOIO2 
0000 OOOI2 



Result: 0100 001 12 

The resulting byte with bit seven set to 1 is stored in 

location 4891. The condition code is set to 1. 



Exclusive OR (X, XR, XI, XC) 

When the Boolean operator exclusive or is applied 
to two bits, the result is 1 when one, and only one, of 
the two bits is 1; otherwise, the result is 0. When two 
bytes are exclusive ORed in System/360, each pair of 
bits is handled separately; there is no connection from 
one bit position to another. 



Exclusive OR (XI) 

A frequent use of the exclusive or ( xi ) instniction is 
to invert a bit (change a bit to a 1 or a 1 bit to a 0). 
For example, assume that storage location 8082 con- 
tains 0110 IOOI2. To set the leftmost bit to 1 and the 
rightmost bit to without affecting any of the other 
bits, the following instruction can be used (assume 
that register 9 contains 00 00 80 80) : 

Machine Format Assembler Format 

OP CODE 12 Bl Dl OP CODE Dl Bl 12 



97 



81 



9 



002 



XI 2(9),X'81' 

When the instruction is executed, the byte in storage 
is exclusive ORed with the immediate byte: 



Location 8082: 
Immediate byte: 



0110 IOOI2 
1000 OOOI2 



Result: 1110 IOOO2 

The resulting byte with the leftmost and rightmost bits 
inverted is stored in location 8082. The condition code 
is set to 1. 



Exclusive OR (XC) 

The EXCLUSIVE or (xc) instruction can be used to ex- 
change the contents of two areas in storage without 
the use of an intermediate storage area. For example, 
assume that two words are in storage: 





358 






35B 


Wordl 


1 00 


00 


17 


90 1 




360 






363 


Word 2 


1 00 


00 


14 


Oil 



Execution of the instruction (assume that register 7 
contains 00 00 03 58): 
Machine Format 

OP CODE L Bl Dl B2 D2 



D7 


03 


7 


000 


7 


008 



Assembler Format 

OP CODE Dl L Bl D2 B2 

~XC 0(4,7),8(7) 
exclusive or's word 1 with word 2 as follows: 

Word 1: 0000 0000 0000 0000 0001 0111 1001 OOOO2 = 00 00 17 90 
Word 2: 0000 0000 0000 0000 0001 0100 0000 OOOI2 = 00 00 14 01 

Result: 0000 0000 0000 0000 0000 0011 1001 OOOI2 = 00 00 03 91 

The result replaces the former contents of word 1. 
Now, execution of the instruction: 
Machine Format 

OP CODE L Bl Dl B2 D2 



D7 


03 


7 


008 


7 


000 



Assembler Format 

OP CODE Dl L Bl D2 B2 

XC 8(4,7),0(7) 
produces the following result: 

Wordl: 0000 0000 0000 0000 0000 0011 1001 OOOI2 = 00 00 03 91 
Word 2: 0000 0000 0000 0000 0001 0100 0000 OOOI2 = 00 00 14 01 

Result: 0000 0000 0000 0000 0001 0111 1001 OOOO2 = 00 00 17 90 

The result of this operation replaces the former con- 
tents of word 2. Word 2 now contains the original 
value of word 1. 

Lastly, execution of the instruction: 
Machine Format 

OP CODE L Bl Dl B2 D2 



D7 


03 


7 


000 


7 


008 



Assembler Format 

OP CODE Dl L Bl D2 B2 

XC 0(4,7),8(7) 
produces the following result: 

Wordl: 0000 0000 0000 0000 0000 0011 1001 OOOI2 = 00 00 03 91 
Word 2: 0000 0000 0000 0000 0001 0111 1001 OOOO2 = 00 00 17 90 

Result: 0000 0000 0000 0000 0001 0100 0000 OOOU = 00 00 14 01 

The result of this operation replaces the former con- 
tents of word 1. Word 1 now contains the original 
value of word 2. 

Notes: 

1. With the xc instruction, fields up to 256 bytes in 
length can be exchanged. 

2. With the xr instruction, the contents of two regis- 
ters can be exchanged. 

3. Because the x instruction operates storage to reg- 
ister only, an exchange cannot be made solely by the 
use of x. 
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4. A field exclusive OR'ed with itself is cleared to 
zeros. 

Test Under Mask (TM) 

The TEST UNDER MASK instruction examines specific bits 

within a byte and sets the condition code according 

to what it finds. For example, assume that: 

Storage location 9999 contains FB 
Register 9 contains 00 00 99 90 

Execution of the instruction: 

Machine Format 

OPCODE 12 Bl Dl 



91 



C3 



9 



009 



Assembler Format 

OPCODE DlBl 12 

TM 9(9),X'C3' 



all selected bits are 



produces the following result: 

FB = 1111 IOII2 
Mask (C3) = IIOOOOII2 

Result = llxx XX 11 

The condition code is set to 3: 
ones. 

If location 9999 had contained B9, the result would 
have been: 

B9 = 1011 IOOI2 
Mask (C3) = 1100 001 12 

Result = lOxx xxOl 

The condition code is set to 1: the selected bits are 
both zeros and ones. 

If location 9999 had contained 3C, the result would 

have been: 

3C z^ 0011 IIOO2 
Mask (C3) = IIOOOOII2 

Result = OOxx xxOO 

The condition code is set to 0: all selected bits are 
zeros. 

Note: Storage -location 9999 remains unchanged. 

Load Address (LA) 

The LOAD ADDRESS instruction provides a convenient 
way to place a non-negative number < 4095io in a reg- 
ister without first defining the number as a constant 
and then using it as an operand. For example, assume 
that the number 2048io is to be placed in register 1. 
One instruction that will do this is: 

Machine Format Assembler Format 

OPCODE Rl X2 B2 D2 OPCODE Rl D2 X2B2 

41 I 1 I I I 800| Ta 1,2048(0,0) 

As indicated in the programming note in the in- 
struction description, the load address instruction can 
also be used to increment a register by an amount < 
4095io specified in the D2 field. For example, assume 
that register 5 contains 00 12 34 56. 

The instruction: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE Rl D2 X2B2 

LA 5,10(0,5) 
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adds 10 (decimal) to the contents of register 5 as fol- 
lows: 

Register 5 (old): 00 12 34 56 
D2: 00 00 00 OA 



Register 5 (new): 00 12 34 60 



41 


5 





5 


OOA 



Translate (TR) 

With the TRANSLATE instruction, System/360 can trans- 
late data from any code to any other desired code, 
provided that each coded character consists of eight 
bits or fewer. In the following example ebcdic is trans- 
I lated to usASCii-8. The first step is to create a 256-byte 
table in storage locations 1000- lOFF. This table con- 
tains the characters of the code into which you are 
translating (the function bytes). The table must be 
in order, not by the binary values of the characters it 
contains, but by the binary sequence of the characters 
of the original code (the argument bytes). For ex- 
ample, note in the table below that the characters are 
in the normal ebcdic collating sequence. 

Translate Table 

^_^_^_^_^_^_^_^_^_^_^_^_^_^_^ 100F 

1000 
1010 
1020 
1030 
1040 
1050 
1060 
1070 
1080 
1090 
lOAO 
lOBO 
lOCO 
lODO 
lOEO 
lOFO 

Notes: 
I 1. The overbars are used to indicate the USASCII-8 representations 
of the EBCDIC characters shown. 

2. If ihe character codes in the statement being translated occupy 
a range smaller than OO16 through FF16, a table of less than 256 
bytes can be used. 

3. The symbol in location t040 represents the coding for a blank, 
I which is the same in both EBCDIC and USASCII-8, 40i6- 
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Because location 204D contains a nonzero value, the 
following actions occur: 

1. The address of the argument byte, 003013, is 
placed in the low-order 24 bits of register 1. 

2. The function byte, 20, is placed in the low-order 
eight bits of register 2. 

3. The condition code is set to 1 (scan not com- 
pleted ) . 

In general, tiia.nslate and test is executed by use 
of an EXECUTE instruction, which supplies the length 
specification from a general register. In this way a 
complete statement scan can be performed with a 
single TRANSLATE AND TEST iustruction repeated over 
and over by means of execute. In the example, after 
the first execution of trt, register 1 contains the ad- 
dress of the last argument byte translated. It is then 
a simple matter to subtract this address from the ad- 
dress of the last argument byte (301D) to produce a 
length specification. This length minus one is placed 
in the register that is referenced as the Ri field of the 
execute instruction. (Because the length code in the 
machine format is one less than the total number of 
bytes in the field, one must be subtracted from the 
computed length.) The branch address part of the 
execute instruction points to the translate and test 
instruction, which must now appear in the following 
format: 

Machine Format 



OP CODE 



Bl 



Dl 



B2 



D2 



DD 


00 


1 


000 


F 


000 



Assembler Format 

OP CODE Dl LBl D2 B2 

TRT 0(0,1),0(15^ 
Now the entire argument field can be scanned, stop- 
ping to examine those characters of special interest, 
without having to modify any of the instructions al- 
ready written. After a stop is made to examine a char- 
acter, only a new length and starting address need be 
computed before continuing the scan. 

Edit (ED) 

Because the decimal feature instructions operate only 
on packed decimal data, it is necessary to convert the 
data to the koned format before a legible report can 
be printed. Moreover, if the report is to be useful to a 
great many people, certain punctuation marks, such as 
commas and decimal points, should be inserted in 
appropriate places. The highly flexible edit instruction 
performs these two functions in a single execution. 

This example shows step-by-step one way in which 
EDIT can be used. The field to be edited (the source) 
is four bytes long; it is edited against a pattern 13 
bytes long. The following symbols are used: 



SYMBOL 

b (hexadecimal 40) 
( ( hexadecimal 21 ) 
d ( hexadecimal 20 ) 
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MEANING 

blank character 
significance starter 
digit selector 



Assume that the source and pattern fields are: 



Source 

1200 



02 I 57 I 42 6C 



J 



Pattern 



1000 


















lOOC 


1 40 1 20 


20 


6B 


20 


20 


21 


|4B 


20 


20 


40 1 C3 1 D9 


•-^ '-^ 


■-^ 


s.^ 


<_^ 


^^ 


•~^ 


^^ 


— ^ 


^^ 


^^ •^^ ^^ 



R 



b d d , d d ( . d d b 

Execution of the instruction ( assume that register 12 
contains 00 00 10 00): 



Machine Format 

L Bl Dl 



B2 



D2 



DE 


OC 


c 


000 


c 


200 



Assembler Format 

OPCODE Dl L Bl D2 



B2 



ED 0(13,12),X'200'(12) 
alters the pattern as follows: 







INDICATOR 






PATTERN 


DIGIT 


before/after 


RULE 


LOCATION 1000-lOOC 


b 




off/ofF 


leave(l) 


bdd,dd(.ddbCR 


d 





ofF/off 


fill 


bbd,dd(.ddbCR 


d 


2 


off /on (2) 


digit 


bb2,dd(.ddbCR 






on/on 


leave 


same 


d 


5 


on/on 


digit 


bb2,5d(.ddbCR 


d 


7 


on/on 


digit 


bb2,57(.ddbCR 


( 


4 


on/on 


digit 


bb2,574.ddbCR 






on/on 


leave 


same 


d 


2 


on/on 


digit 


bb2,574.2dbCR 


d 


6+ 


on/off (3) 


digit 


bb2,574.26bCR 


b 




off/off 


fill 


same 


c 




off/off 


fill 


bb2,574.26bbR 


R 




off/off 


fill 


bb2,574.26bbb 



Notes: 

1. This character becomes the fill character. 

2. First nonzero decimal source digit turns on significance 
indicator. 

3. Plus sign in the four low-order bits of the byte turns off 
significance indicator. 



Thus, after the instruction is executed: 



Source Unchanged 
Pattern 



1000 
























lOOC 


140 


40 


F2 


6B 


F5 


F7 


F4 


4B 


F2 


F6 


40 


40 


|40 1 


^v--- 


■^^ 


•^^: 


-^^ 


^^ 


^^ 


^.v-- 


^.^ 


■-v^ 


■^^ 


^s^ 


■-v^ 


^^ 



bb2 ,574 .26bbb 
Condition code = 2: result greater than zero. 

When printed, the pattern field, which now contains 
the result, appears as: 

2,574.26 
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If the number in the source field is changed to 
00 00 02 6D, a negative number, and the original pat- 
tern is used, the edited result becomes: 

Pattern 

1000 lOOC 

[T07T074O I 4 I 40 I 40 I 40 I 4B I F2 I F6 I 40 I C3 I DO] 

b bbT^YbX^TXeVc R 
Condition code = 1; result less than zero 

The significance starter forces the significance indi- 
cator to the on state and hence causes the decimal 
point to be left unchanged. Because the minus sign 
does not change the significance indicator, the cr 
symbol is also preserved. 

Edit and Mark (EDMK) 

After an edit-and-mark operation, a symbol (such as 
a dollar sign) can be inserted at the appropriate posi- 
tion in the edited result. Usually a currency symbol 
is inserted to the immediate left of the first significant 
digit in the amount; however, if a decimal point ap- 
pears in an amount less than one, the currency symbol 
must be inserted to the immediate left of the decimal 
point, A typical operation would leave no blank be- 
tween the currency symbol and the amount, thus pro- 
tecting against one form of alteration when the result 
is printed on a check. 

If significance is not forced by the significance 
starter, the edit-and-mark operation inserts into gen- 
eral register 1 an address one more than the address 
at which a currency symbol would normally be in- 
serted. After one is subtracted from the value in gen- 
eral register 1 (for example, by using a branch on 
COUNT instruction with Ri set to one and R2 set to 
zero), a move instruction (mvi) may be used to posi- 
tion the symbol in main storage. 

Machine Format Assembler Format 

OP CODE I2 Bi Di OP CODE Dj Bj I2 



92 



5D 



100 



.____^__^__^ ^^^ 0(1),C'$' 

If significance is forced, general register 1 remains 
unchanged. Therefore, the address of the character 
following the significance starter should be placed in 
that register before the edit and mark instruction is 
performed. 

Decimal Arithmetic 

Add Decimal (AP) 

Assume that the signed, packed-decimal field at stor- 
age locations 500-503 is to be added to the signed, 
packed-decimal field at locations 2000-2002. Also 
assume: 

Register 12 contains 00 00 20 00 

Register 13 contains 00 00 04 FD 

Storage locations 2000-2002 contain 38 46 OD ( a neg number ) 

Storage locations 500-503 contain 01 12 34 5C ( a pos number ) 



After the instruction: 

Machine Format 

OP CODE Ll L2 Bl Dl 



B2 



D2 



FA 


2 


3 


C 


000 


D 


003 



Assembler Format 

OP CODE Dl LlBl D2 L2B2 

AP 0( 3,12 ),3( 4,13) 

is executed, the storage locations 2000-2002 contain 
73 88 5C; the condition code is set to 2 to indicate that 
the sum is positive. Note that: 

1. Although the second operand field is larger than 
the first operand field, no overflow interruption occurs 
because the result can be entirely contained within the 
first operand field. 

2. Because the two numbers had different signs, 
they were in effect subtracted. 

Zero and Add (ZAP) 

Assume that the signed, packed-decimal field at stor- 
age locations 4500-4502 is to be moved to locations 
4000-4004 with four leading zeros in the result field. 
Also assume: 

Register 9 contains 00 00 40 00 

Storage locations 4000-4004 contain 12 34 56 78 90 

Storage locations 4500-4502 contain 38 46 OD 

After the instruction: 

Machine Format 

OP CODE Ll L2 Bl Dl B2 D2 



F8 


4 


2 


9 


000 


9 


500 



Assembler Format 

OP CODE Dl LIB! D2 L2B2 

ZAP 0(5,9),X'500'(3,9) 

is executed, the storage locations 4000-4004 contain 
00 00 38 46 OD; the condition code is set to 1 to indi- 
cate a negative result. Note that because the first 
operand is not checked for valid sign and digit codes, 
it may contain any combination of hexadecimal digits. 

Compare Decimal (CP) 

Assume that the signed, packed-decimal contents of 
storage locations 700-703 are to be algebraically com- 
pared with the signed, packed-decimal contents of lo- 
cations 500-503. Also assume: 

Register 12 contains 00 00 06 00 

Register 13 contains 00 00 04 00 

Storage locations 700-703 contain 17 25 35 6D 

Storage locations 500-503 contain 06 72 14 2D 

After the instruction: 

Machine Format 

OP CODE Ll L2 Bl Dl B2 D2 



F9 


3 


3 


C 


100 


D 


100 1 
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Assembler Format 

OPCODE Dl LlBl D2 L2B2 

CP X'100'(4,12),X'100'(4,13) 

is executed, the condition code is set to 1, indicating 
that the first operand (the contents of locations 700- 
703) is lower than the second. 

Multiply Decimal (MP) 

Assume that the signed, packed-decimal field in stor- 
age locations 1202-1204 (the multiplicand) is to be 
multiplied by the signed, packed-decimal field in lo- 
cations 500-501 (the multiplier): 





1202 




1204 


Multiplicand 


38 


46 


OD 




500 


501 




Multiplier 


1 32 


ID 





Because there are a total of eight significant digits in 
the multiplier and multiplicand, a field at least five 
bytes in length must be reserved for the signed result. 
As indicated in the programming note for multiply 
DECIMAL, a ZERO AND ADD into a larger field can provide 
the required space. If it is assumed: 

Register 4 contains 00 00 12 00 
Register 6 contains 00 00 05 00 

then execution of the assembler instruction: 

ZAP X'100'(5,4),2(3,4) 

sets up a new multiplicand in storage locations 1300- 
1304: 



1300 



1304 



Multiplicand (new) | 00 | 00 | 38 | 46 | OD ] 

Now, after the instruction: 
Machine Format 

OP CODE Ll L2 Bl Dl B2 D2 



FC 


4 


1 


4 


100 


6 


000 



Assembler Format 

OP CODE Dl LlBl D2 L2B2 

MP 



X'100'( 5,4), 0(2,6) 

is executed, storage locations 1300-1304 contain the 
product: 01 23 45 66 OC. 



Divide Decimal (DP) 

Assume that the signed, packed-decimal field at stor- 
age locations 2000-2004 (the dividend) is to be di- 
vided by the signed, packed-decimal field at locations 
3000-3001 (the divisor). Also assume: 

Register 12 contains 00 00 20 00 

Register 13 contains 00 00 30 00 

Storage locations 2000-2004 contain 01 23 45 67 8C 

Storage locations 3000-3001 contain 32 ID 



After the instruction: 

Machine Format 

OP CODE Ll L2 



Bl 



Dl 



B2 



D2 



FD 


4 


1 


C 


000 


D 


000 



2000 




2004 


38 1 46 1 OD 


01 


|8C| 


V. / 




V ' 



Assembler Format 

OPCODE DlLlBl D2L.2B2 

DP 0(5,12),0(2,13) 

is executed, the dividend field is entirely replaced by 
the signed quotient and remainder fields, as follows: 



Locations 2000-2004 



quotient remainder 
Notes: 

1. Because the signs of the dividend and divisor are 
different, the quotient receives a negative sign. 

2. The remainder receives the sign of the dividend 
and the length of the divisor. 

3. If an attempt is made to divide the dividend by 
the one-byte field at location 3001, the quotient will be 
too long to fit within the four bytes allotted to it. A 
decimal-divide exception exists, causing a program 
interruption. 



Pack (PACK) 

Assume that storage locations 1000-1004 contain the 
following zoned-decimal field that is to be converted 
to a packed-decimal field and left in the same location: 

1000 1004 



Zoned Field Fl | F2 I F3 I F4 I C5 



Also assume that register 12 contains 00 00 10 00. 
After the instruction: 

Machine Format 

OP CODE Ll L2 Bl Dl 



B2 



D2 



F2 


4 


4 


C 


000 


c 


000 



Assembler Format 

OPCODE DiLlBl D2L2B2 

PACK 0( 5,12 ) ,0(5,12) 

is executed, the field in locations 1000-1004 is in the 
packed-decimal format: 

1000 1004 

Packed Field [ 00 | 00 | 12 | 34 | 5C | 

Notes: 

1. This example illustrates the operation of pack 
when the first and second operand fields overlap com- 
pletely. 

2. During the operation, the second operand was 
extended with high-order zeros. 



Appendix A 136.3 



Unpack (UNPK) 

Assume that storage locations 2501-2503 contain a 

signed, packed-decimal field that is to be unpacked 

and placed in storage locations 1000-1004. Also assume: 

Register 12 contains 00 00 10 00 

Register 13 contains 00 00 25 00 

Storage locations 2501-2503 contain 12 34 5D 

The initial contents of storage locations 1000-1004 are not 

significant 
PSW bit 12 = (EBCDIC mode) 

After the instruction: 

Machine Format 



OP CODE 


LI 


L2 


Bl 


Dl 


B2 


D2 


F3 


4 


2 


C 


000 


D 


001 



Assembler Format 

OPCODE DlLlBl D2L2B2 

UNPK 0(5,12),1(3,13) 

is executed, the storage locations 1000-1004 contain 
Fl F2 F3 F4 D5. Because the cpu was in ebcdic mode, 
the zone IIII2 = Fie was attached to all digits except 
the digit occupying the same byte as the sign. 

Move with Offset (MVO) 

Assume that the unsigned three-byte field in storage 

locations 4500-4502 is to be moved to locations 5600- 

5603 and given the sign of the one-byte field located 

at 5603. Also assume: 

Register 12 contains 00 00 56 00 

Register 15 contains 00 00 45 00 

Storage locations 5600-5603 contain 77 88 99 OC 

Storage locations 4500-4502 contain 12 34 56 

After the instruction: 

Machine Format 



OP CODE 


Ll 


L2 


Bl 


Dl 


B2 


D2 


Fl 


3 


2 


C 


000 


F 


000 



Assembler Format 

OPCODE DlLlBl D2L2B2 

MVO 0(4,12),0(3,15) 

is executed, the storage locations 5600-5603 contain 
01 23 45 6C. Note that the second operand was ex- 
tended with one high-order zero to fill out the first 
operand field. 

Note: The section "Shifting of Decimal Fields" 
shows how MOVE WITH OFFSET cau be used in shifting 
a decimal field an odd number of places. 

Shifting of Decimal Fields 

No instructions have been specifically provided to per- 
form shifting of decimal fields in storage. However, 
various combinations of System/360 instructions may 
be used to accom.plish in effect this type of shift. The 
following assembly-language examples illustrate some 
of the methods for shifting decimal numbers. These 



examples additionally illustrate how the assembly lan- 
guage facilitates coding with symbolic operands. 

Decimal Right Shift (Even Number of Places) 

Assume that symbolic storage location source contains 
12 34 56 78 9C, and you wish to shift the contents of 
SOURCE two places to the right (to drop the rightmost 
two digits, thereby dividing source by lOOio). The 
MOVE numerics ( MVN ) instnictiou can be used to ac- 
complish this: 

MVN SOURCE-|-3(l),SOURCE+4 
After the mvn instruction is executed, source con- 
tains 12 34 56 7C.9C. Instructions referencing source 
should now use a length of 4 instead of 5, 

Decimal Right Shift (Odd Number of Places) 

Assume that symbolic storage location source con- 
tains 12 34 56 78 9C, and you wish to shift the contents 
of source three places to the right ( to drop the right- 
most three digits, thereby dividing source by lOOOio). 
The move with offset (mvo) instruction can be used 
to accomplish this: 

MVO SOURCE(5),SOURCE(3) 
After this instruction is executed, source contains 
00 01 23 45 6C. 

Decimal Left Shift (Even Number of Places) 

Assume that symbolic location zero contains 00 00 and 
that source contains 12 34 56 78 9C. The contents of 
source can be shifted four places to the left by using 
the following group of instructions: 



MVC SOURCE -1-5(2), ZERO 
MVN SOURCE -|-6(l),SOURCE-f 4 
NI SOURCE -1-4,240 



SOURCE 

12 34 56 78 9C 00 00 
12 34 56 78 9C 00 OC 
12 34 56 78 90 00 OC 



Note that the number 240io in the and (ni) instruc- 
tion provides a mask of 1111 OOOO2, which is used to 
make the old sign position zero. 

Decimal Left Shift (Odd Number of Places) 

Assume that symbolic location zero contains 00 00 and 
that source contains 12 34 56 78 9C. The contents of 
source can be shifted three places to the left by using 
the following group of instructions: 

SOLTRCE 

12 34 56 78 9C 00 00 
12 34 56 78 9C 00 OC 
12 34 56 78 90 00 OC 
01 23 45 67 89 00 OC 



MVC 

MVN 

NI 

MVO 



SOURCE -f 5(2), ZERO 
SOURCE-|-6( 1 ),SOURCE-|-4 
SOURCE -(-4,240 
SOURCE ( 6 ) ,SOURCE ( 5 ) 



Floating-Point Arithmetic 

In this section, the abbreviations fpro, fpr2, fpr4, and 
FPR6 stand for floating-point registers 0, 2, 4, and 6, 
respectively. 
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Add Normalized (AE, AER, AD, ADR) 

The ADD NORMALIZED instructions perform the addition 
of two floating-point numbers and place the normal- 
ized result in a floating-point register. Neither of the 
two numbers to be added must necessarily be normal- 
ized before addition occurs. For example, assume that: 

FPR6 contains 43 08 21 00 00 00 00 00 = 82. lie s 130.6 

( unnormalized ) 
Storage locations 2000-2007 contain 41 12 34 56 00 00 00 00 = 

1.2345616 a l-13io (normalized) 
Register 13 contains 00 00 20 00 

The instruction: 

Machine Format Assembler Format 

OP CODE Rl X2 B2 D2 OP CODE R1D2 X2B2 

7A I 6 I I D I 000 I ~~AE 6,0(0,13) 

can be used to perform the short-precision addition of 
the two operands. In this example the instruction 
operates as follows: 

The characteristics of the two numbers are com- 
pared. Since the number in storage has a characteristic 
that is smaller by 2, it is right-shifted after fetching 
until the characteristics agree. The two numbers are 
then added: 

GUARD 
DIGIT 

FPR6: 43 08 21 00 

Shifted number from storage; 43 00 12 34 5 

Intermediate sum: 43 08 33 34 5 

Because the intermediate sum is unnormalized, it is 
left-shifted to form the normalized floating-point num- 
ber 42 83 33 45 ( = 83.3345ie = 131.1io). This number 
replaces the high-order portion of fpr6. The low-order 
portion of fpr6 and the contents of storage locations 
2000-2007 are unchanged. 

If the long-precision instruction ad is used, the re- 
sult in FPR6 will be 42 83 33 45 60 00 00 00. Note that in 
this case, the use of the long-precision instruction pro- 
vides one additional hexadecimal digit of precision. 

Add Unnormalized (AU, AUR, AW, AWR) 

The add unnormalized instructions operate identical- 
ly to the add normalized instructions, except that the 
final result is not normalized when add unnormalized 
is used. For example, using the same operands as in 
the example for add normalized, when the short- 
precision instruction: 

Machine Format Assembler Format 

OPCODE Rl X2 B2 D2 OPCODE RlD2 X2B2 

7E I 6 I I D I OOP I AU 6,0(0,13) 

is executed, the two numbers are added as follows: 



FPR6: 43 08 21 00 

Shifted number from storage: 43 00 12 34 



GUARD 
DIGIT 



Sum: 



43 08 33 34 



The guard digit participates in the addition but is dis- 
carded. The unnormalized sum replaces the high-order 
portion of fpr6. 

If the result in fpr6 is converted to a normalized 
number (42 83 33 40 00 00 00 00) and is compared 
to the result in fpr6 when add normalized was used 
(42 83 33 45 00 00 00 00), in this case it is apparent 
that the use of add normalized ( with the retention of 
the guard digit ) has preserved some additional signifi- 
cance in the result. 

Compare (CE, CER, CD, CDR) 

Assume that fpr4 contains 43 00 00 00 00 00 00 00 
(= 0), and FPR6 contains 35 12 34 56 78 9A BC DE 
( a positive number ) . The contents of the two registers 
are to be compared with the following long-precision 
instruction: 

Machine Format Assembler Format 

OP CODE Rl R2 OP CODE RlR2 

29 I 4 I 6 I CDR 4^6 

When this instruction is executed, the number with 
the smaller characteristic is taken from the register 
and right-shifted until the two characteristics agree. 
The shifted contents of fpr6 are 43 00 00 00 00 00 00 00. 
Therefore, when the two numbers are compared, the 
condition code is set to 0, indicating an equality. 

As the above example implies, when floating-point 
numbers are compared, more than two numbers may 
compare equally if one of the numbers is unnormal- 
ized. For example, the unnormalized floating-point 
number 41 00 12 34 56 78 9A BC compares equally with 
all numbers of the form 3F 12 34 56 78 9A BC XX 
(X represents any hexadecimal number). When the 
compare instruction is executed, the X's are shifted 
right two places and do not participate in the com- 
parison. Note, however, that when two normalized 
floating-point numbers are compared, the relationship 
between numbers that compare equally is unique: 
each digit in one number must be identical to the cor- 
responding digit in the other number. 

Status Switching 

Supervisor Call (SVC) 

The supervisor call instruction allows a program that 
is operating in the problem state to switch the CPU to 
the supervisor state. At the same time, the problem 
program can make a byte of information available to 
the supervisor program. For example, the instruction : 
Machine Format Assembler Format 

OP CODE I OP CODE I 

OA I ol~| ^ SVC 1 

causes a supervisor-call interruption. The byte of in- 
formation (0000 OOOI2) is placed in the interruption- 
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code field of the supervisor call old psw ( storage lo- 
cation 23i6), and a new psw is fetched from location 
6O16. The information byte may indicate, for example, 
that certain conditions encountered during processing 
require further attention (e.g., the job has been com- 
pleted and a printout of storage is desired ) . 

Set Storage Key (SSK) 

Assume that the storage block corresponding to ad- 
dresses soo-FFF has bits 11110 set into its storage key 
(that is, only programs with a protection key of or 
15io can store data in this block, but any program can 
fetch data). Also assume that: 

Register 5 contains 00 00 OA 60 
Register 6 contains 00 00 00 FO 

When the instruction: 

Machine Format Assembler Format 

OP CODE Rl R2 OP CODE RlR2 



08 


6 


5 



SSK 6,5 

is executed, bits 8-20 of register 5 are examined; their 
value indicates which block of 2,048 10 bytes is to have 
its key set: 

Register 5 (bits 8-20) : 0000 0000 0000 1 
In this case register 5 indicates that the "first" block 
( addresses soo-fff ) is the block being addressed. Note 
that register 5 will contain all zeros if the block con- 
taining addresses ooo-7ff is being addressed. Also note 
that it is not necessary for R2 to contain the exact 
address of the first byte in the block (i.e., 00 00 08 00) 
because only bits 8-20 of R2 are examined. 

The key setting for the storage block indicated by 
register 5 is obtained from bits 24-28 of register 6: 
Register 6 ( bits 24-28 ) 11110 

If the fetch protection feature is installed, and it is 
desired to prevent fetching as well as storing of data 
in locations 800-fff, the low-order bit of the storage 
key must be set to 1. This bit can be set to 1 if bit 28 
of register 6 is set to 1 before the execution of ssk. 
( The register could contain 00 00 00 F8, for example. ) 



Insert Storage Key (ISK) 

Assume that the key of the storage block containing 

addresses 800-fff is to be inspected and that: 

Register 5 contains 00 00 08 00 
Register 6 contains FF FF FF FF 



Execution of the instruction: 
Machine Format 



Rl 



R2 



09 6 


5 



Assembler Format 
OP CODE R1R2 
isic 6^5 



changes the contents of register 6 to: 

1111 1111 1111 1111 1111 1111 MMMM MOOO, where 

MMMMM represents the five-bit storage key. Note 

that the last M is set to if fetch protection is not 

installed. 



Test and Set (TS) 

The TEST AND SET instruction can be used to control the 
sharing of a storage area that is used in common by 
more than one program. Assume that the convention 
has been established that when the leftmost bit of an 
indicator byte is set to 1, it is a signal to all other 
programs not to attempt to access the storage area. 
When a program has finished using the storage area, 
it can then set the leftmost bit of the indicator byte to 
0, indicating that other programs may now access the 
area. 

For example, assume that register 10 contains the 
address of the indicator byte (00 00 34 56) and that 
the indicator byte itself initially contains the bits 
0000 0000. After the instruction: 



Machine Format 

OP CODE Bl Dl 



93 


A 


000 



Assembler Format 

OP CODE Dl Bl 

_ TS 0(10) 

is executed: 

The indicator byte (location 3456) contains bits 1111 1111. 
The condition code is set to zero (indicating that the test re- 
vealed the leftmost bit of the indicator byte was zero). 
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Forni A22-6821-2, -3, -4, -5 
Page Revised 1/13/67 
By TNL N22-0244 

Now, assume that starting at storage location 2100 
there is a sequence of 20io ebcdic characters to be 
translated to usAScn-8: 

Locations 2100-2113: JOHNbJONESb257bW.b95 
Also assume: 

Register 12 contains 00 00 21 00 
Register 15 contains 00 00 10 00 

As the instruction: 

Machine Format 

OP CODE L Bl Dl B2 D2 



DC 



13 



000 



000 



Assembler Format 

OPCODE Dl L Bl D2 B2 

li 0(20,12), 0(15") 
is executed, the binary value of each argument byte is 
added to the starting address of the table, and the re- 
sulting address is used to fetch a function byte: 

Table starting address: 1000 
First argument byte (J): Dl 

Address of function byte: lODl 

Because the table is arranged so that every ebcdic 

character is replaced by the corresponding usascii-8 

character, the result is: 

Locations 2100-2113: JOHNbJONESb257bW.95 

Note: To verify that this example is correct, find in 
Appendix F the hexadecimal values for the remaining 
EBCDIC characters and add them to the starting address 
of the table (1000). The sums should be the ad- 
dresses within the table of the corresponding usAScn-8 
characters. 



Translate and Test (TRT) 

The TRANSLATE AND TEST instruction is used to scan a 
data field (the argument bytes) for characters with 
special meaning. To indicate which characters have 
special meaning, first set up a table similar to the one 
used for the translate instruction. ( See the preceding 
example.) Once again the table must be in order by 
the binary sequence of the code of the argument bytes. 
This time, however, put zeros in the table to indicate 
characters without any special meaning and nonzero 
values to indicate characters with special meaning. 

This example deals with ebcdic characters; the char- 
acters with special meaning in the argument field are 
a selected set of punctuation marks. The translate and 
test table that follows has been set up accordingly. 

Now, assume that starting at storage location 3000 
you have the following sequence of 30io ebcdic char- 
acters: 



Translate and Test Table 



200F 



2000 
2010 
2020 
2030 
2040 
2050 
2060 
2070 
2080 
2090 
20A0 
20B0 
20C0 
20D0 
20E0 
20F0 



00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


10 


20 


25 


00 


90 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


30 


35 


40 


45 


00 


80 


85 


00 


00 


00 


00 


00 


00 


00 


00 


00 


50 


55 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


60 


65 


70 


75 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 


00 



Note: If the character codes in the statement being translated occupy 
a range smaller than 00i6 through FFie, a table less than 256 bytes 
can be used. 



Also assume: 

Register 1 contains 00 00 30 00 
Register 2 contains 00 00 00 00 
Register 15 contains 00 00 20 00 

As the instruction: 

Machine Format 

OP CODE L Bl Dl B2 D2 



DD 


ID 


1 


000 


F 


000 



Locations 3000-301D: 



Assembler Format 

OPCODE Dl LBl D2 B2 

TRT 0(30,1),0(15) 
is executed, the value of the first argument byte, a 
blank, is added to the starting address of the table to 
produce the address of the function byte to be ex- 
amined: 

Table starting address 2000 

First argument byte ( blank ) 40 

Address of function bye 2040 

Because zeros were originally placed in storage loca- 
tion 2040, no special action occurs, and the operation 
continues with the second argument byte. The opera- 
tion will thus continue until it reaches the symbol ( 
(left parenthesis) in location 3013. When this symbol 
is reached, its value is added to the starting address 
of the table, as usual : 

Table starting address 2000 

Argument byte (left parenthesis) 4D 



bbbbbUNPKbbbbbPROUT(9),WORD(5) Address of function byte 



204D 
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Appendix B. Fixed-Point and Two's Complement Notation 



A fixed-point number is a signed value, recorded as a 
binary integer. It is called fixed point because the pro- 
grammer determines the fixed positioning of the binary 
point. 

Fixed-point operands may be recorded in halfword 
(16 bits) or word (32 bits) lengths. In both lengths, 
the first bit position (0) holds the sign of the number, 
with the remaining bit positions (1-15 for halfwords 
and 1-31 for fullwords) used to designate the mag- 
nitude of the number. 

Positive fixed-point numbers are represented in true 
binary form with a zero sign bit. Negative fixed-point 
numbers are represented in two's complement notation 
with a one bit in the sign position. In all cases, the 
bits between the sign bit and the leftmost significant 
bit of the integer are the same as the sign bit (i.e. 
all zeros for positive numbers, all ones for negative 
numbers ) . 

Negative fixed-point numbers are formed in two's 
complement notation by inverting each bit of the posi- 
tive binary number and adding one. For example, the 
true binary form of the decimal value (plus 26) is 
made negative (minus 26) in the following manner: 



COMMENTS 



+26 

Invert 

Addl 

-26 



S INTEGER 

0000000 00011010 

1 1111111 11100101 

1^ 

1111111111 1001 10 ( Two's complement form ) 



This is equivalent to subtracting the number: 
00000000 00011010 from 1 00000000 00000000. 

The following addition examples illustrate two's 
complement arithmetic. Only eight bit positions are 
used. All negative numbers are in two's complement 
form. 



+57 
+92 

149 



= 00111001 

= 00100011 

= 01011100 

= 00111001 

= 11011101 



+57 
+35 

+92 

+57 

-35 

+22 = 00010110 



+ 35 = 00100011 

-57 = 11000111 

^2 = 11101010 

-57 = 11000111 

-35 = 11011101 

-92 = 10100100 



-57 = 11000111 
-92 = 10100100 

Il49 = *01 101011 



= 00111001 
= 01011100 

= *10010101 



No overflow 

Ignore carry — carry into high 
order position and carry out. 



Sign change only; no carry. 

No overflow 

Ignore carry — carry into high 
order position and carry out. 



* Overflow — no carry into high 
order position but carry out. 



NUMBER 




DECIMAL 


2*" -1 


zz. 


32,767 


2° 


= 


1 





= 





-2" 


=. 


-1 


-2"" 


= 


-32,768 



Overflow — carry into high order 
position, no carry out. 

The following are 16-bit fixed-point numbers. The 
first is the largest positive number and the last, the 
largest negative number. 

S INTEGER 

=0 111111111111111 
=0 0000000 00000001 
=0 0000000 00000000 

=1 111111111111111 

= 1 0000000 00000000 
The following are 32-bit fixed-point numbers. The 
first is the largest positive number that can be repre- 
sented by 32 bits, and the last is the largest negative 
number. 

NUMBER DECIMAL S INTEGER 

231-1 = 2 147 483647=0 1111111111111111111111111111111 

216 = 65 536=0 0000000 0000000100000000 00000000 

20 = 1=0 0000000 0009000000000000 00000001 

= 0=0 0000000 0000000000000000 00000000 

-20 = -1=11111111111111111111111111111111 

-21 = -2=11111111111111111111111111111110 

-216 = -65 536=111111111111111100000000 00000000 

-231 +1 = -2 147 483 647 =1 0000000 0000000000000000 00000001 

_23i = -2 147 483 648 =1 0000000 0000000000000000 00000000 



Appendix B 137 



Appendix C. Floating-Point Arithmetic 



Floating-point arithmetic simplifies programming by 
automatically maintaining binary point placement 
(scaling) during computations in which the range of 
values used vary vi^idely or are unpredictable. 

The key to floating-point data representation is the 
separation of the significant digits of a number from 
the size (scale) of the number. Thus, the number is 
expressed as a fraction times a power of 16. 

A floating-point number has two associated sets of 
values. One set represents the significant digits of the 
number and is called the fraction. The second set 
specifies the power (exponent) to which 16 is raised 
and indicates the location of the binary point of the 
number. 

These two numbers (the fraction and exponent) are 
recorded in a single word or double word. 

Since each of these two numbers is signed, some 
method must be employed to express two signs in an 
area that provides for a single sign. This is accom- 
plished by having the fraction sign use the sign associ- 
ated with the word (or double word) and expressing 
the exponent in excess 64 arithmetic; that is, the ex- 
ponent is added as a signed number to 64. The result- 
ing number is called the characteristic. Since 64 uses 7 
bits, the characteristic can vary from to 127, permit- 
ting the exponent to vary from —64 through to +63. 
This provides a decimal range of n x lO^'^ to n x 10—''^^. 

Floating-point data in the System/360 may be re- 
corded in short or long formats, depending on the 
precision required. Both formats use a sign bit in bit 
position 0, followed by a characteristic in bit positions 
1-7. Short-precision floating-point data operands con- 
tain the fraction in bit positions 8-31; long-precision 
operands have the fraction in bit positions 8-63. 

Short-Precision Floafing-Poini Format 



s 


Characteristic 


Fraction 



Long-Precision Floating-Point Forntat 



s 


Characteristic 


Fraction yt 



The sign of the fraction is indicated by a zero or one 
bit in bit position to denote a positive or negative 
fraction, respectively. 



Within a given fraction length (24 or 56 bits), a 
floating-point operation will provide the greatest pre- 
cision if the fraction is normalized. A fraction is nor- 
malized when the high-order digit (bit positions 8, 
9, 10 and 11) is not zero. It is unnormalized if the 
high-order digit contains all zeros. 

If normalization of the operand is desired, the float- 
ing-point instructions that provide automatic normal- 
ization are used. This automatic normalization is ac- 
complished by left-shifting the fraction (four bits per 
shift) until a nonzero digit occupies the high-order 
digit position. The characteristic is reduced by one? for 
each digit shifted. 

Conversion Example 

Convert the decimal number 149.25 to a short-preci- 
sion floating-point operand. (Appendix E provides 
tables for conversion of hexadecimal and decimal inte- 
gers and fractions.) 

1. The number is decomposed into a decimal integer 
and a decimal fraction. 

149.25 = 149 plus 0.25 

2. The decimal integer is converted to its hexadeci- 
mal representation. 



149,, 



= 95i, 



3. The decimal fraction is converted to its hexadeci- 
mal representation. 

0.25,0 = 0.4i6 

4. Combine the integral and fractional parts and ex- 
press as a fraction times a power of 16 ( exponent ) . 

95.4,6 = (0.954 X 10')ie 

5. The characteristic is developed from the expon- 
ent and converted to binary. 

base -|- exponent = characteristic 

64 + 2 =66 =1000010 

6. The fraction is converted to binary and grouped 
hexadecimally. 

.954x6 = .1001 0101 0100 

7. The characteristic and the fraction are stored in 

short precision format. The sign position contains the 

sign of the fraction. 

S Char Fraction 

" 1000010 100101010100 0000 0000 0000 
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The following are sample normalized short floating- 
point numbers. The last two numbers represent the 
smallest and the largest positive normalized numbers. 



POWERS OF 16 S CHAR 



1.0 

0.5 
1/64 
0.0 

-15.0 = -15/16 X 161 
5.4 X 10-78 -^ + 1/16 X 16-64 
7 X 10" ■S' (1-16-6) X 16«3 



= +1/16 X 161 
= +8/16 X 160 
= +4/16 X 16-1 
= +0 X 16-64 



= 1000001 
= 1000000 
=00111111 
=0 0000000 
= 1 1000001 
"SO 0000000 
^0 1111111 



FRACTION 

0001 0000 0000 0000 0000 0000 
1000 0000 0000 0000 0000 0000 
0100 0000 0000 0000 0000 0000 

0000 0000 0000 0000 0000 0000 
1111 0000 0000 0000 0000 0000 

0001 0000 0000 0000 0000 0000 

1111 1111 1111 1111 1111 1111 
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Appendix D. Powers of Two Table 



2" n 2-« 

1 1.0 

2 1 0.5 
4 2 0.25 
8 3 0.125 

16 4 0.062 5 

32 5 0.031 25 

64 6 0.015 625 

128 7 0.007 812 5 

256 8 0.003 906 25 

512 9 0.001 953 125 

1 024 10 0.000 976 562 5 

2 048 11 0.000 488 28125 

4 096 12 0.000 244 140 625 

8 192 13 0.000 122 070 312 5 

16 384 14 0.000 061 035 156 25 

32 768 15 0.000 030 517 578 125 

65 536 16 0.000 015 258 789 062 5 

131 072 17 0.000 007 629 394 531 25 

262 144 18 0.000 003 814 697 265 625 

524 288 19 0.000 001 907 348 632 812 5 

1 048 576 20 0.000 000 953 674 316 406 25 

2 097 152 21 0.000 000 476 837 158 203 125 

4 194 304 22 0.000 000 238 418 579 101 562 5 

8 388 608 23 0.000 000 119 209 289 550 781 25 

16 777 216 24 0.000 000 059 604 644 775 390 625 

33 554 432 25 0.000 000 029 802 322 387 695 312 5 

67 108 864 26 0.000 000 014 901 161 193 847 656 25 

134 217 728 27 0.000 000 007 450 580 596 923 828 125 

268 435 456 28 0.000 000 003 725 290 298 461 914 062 5 

536 870 912 29 0.000 000 001 862 645 149 230 957 031 25 

1 073 741 824 30 0.000 000 000 931 322 574 615 478 515 625 

2 147 483 648 31 0.000 000 000 465 661 287 307 739 257 812 5 

4 294 967 296 32 0.000 000 000 232 830 643 653 869 628 906 25 

8 589 934 592 33 0.000 000 000 116 415 321 826 934 814 453 125 

17 179 869 184 34 0.000 000 000 058 207 660 913 467 407 226 562 5 

34 359 738 368 35 0.000 000 000 029 103 830 456 733 703 613 281 25 
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Appendix E. Hexadecimal Tables 



The following tables aid in converting hexadecimal 
values to decimal values, or the reverse. 



Direct Conversion Table 

This table provides direct conversion of decimal and 
hexadecimal numbers in these ranges; 



HEXADECIMAL 

000 to FFF 



DECIMAL 

0000 to 4095 



For numbers outside the range of the table, add the 
following values to the table figures: 



HEXADECIMAL 
1000 
2000 

3000 
4000 
5000 
6000 
7000 
8000 
9000 
AOOO 
BOOO 
COOO 
DOOO 
EOOO 
FOOO 



DECIMAL 
4096 

8192 
12288 
16384 
20480 
24576 
28672 
32768 
36864 
40960 
45056 
49152 
53248 
57344 
61440 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


00_ 


0000 


0001 


0002 


0003 


0004 


0005 


0006 


0007 


0008 


0009 


0010 


0011 


0012 


0013 


0014 


0015 


01_ 


0016 


0017 


0018 


0019 


0020 


0021 


0022 


0023 


0024 


0025 


0026 


0027 


0028 


0029 


0030 


0031 


02_ 


0032 


0033 


0034 


0035 


0036 


0037 


0038 


0039 


0040 


0041 


0042 


0043 


0044 


0045 


0046 


0047 


03_ 


0048 


0049 


0050 


0051 


0052 


0053 


0054 


0055 


0056 


0057 


0058 


0059 


0060 


0061 


0062 


0063 


04_ 


0064 


0065 


0066 


0067 


0068 


0069 


0070 


0071 


0072 


0073 


0074 


0075 


0076 


0077 


0078 


0079 


05_ 


0080 


0081 


0082 


0083 


0084 


0085 


0086 


0087 


0088 


0089 


0090 


0091 


0092 


0093 


0094 


0095 


06_ 


0096 


0097 


0098 


0099 


0100 


0101 


0102 


0103 


0104 


0105 


0106 


0107 


0108 


0109 


0110 


0111 


07_ 


0112 


0113 


0114 


0115 


0116 


0117 


0118 


0119 


0120 


0121 


0122 


0123 


0124 


0125 


0126 


0127 


08_ 


0128 


0129 


0130 


0131 


0132 


0133 


0134 


0135 


0136 


0137 


0138 


0139 


0140 


0141 


0142 


0143 


09_ 


0144 


0145 


0146 


0147 


0148 


0149 


0150 


0151 


0152 


0153 


0154 


0155 


0156 


0157 


0158 


0159 


0A_ 


0160 


0161 


0162 


0163 


0164 


0165 


0166 


0167 


0168 


0169 


0170 


0171 


0172 


0173 


0174 


0175 


0B_ 


0176 


0177 


0178 


0179 


0180 


0181 


0182 


0183 


0184 


0185 


0186 


0187 


0188 


0189 


0190 


0191 


0C_ 


0192 


0193 


0194 


0195 


0196 


0197 


0198 


0199 


0200 


0201 


0202 


0203 


0204 


0205 


0206 


0207 


0D_ 


0208 


0209 


0210 


0211 


0212 


0213 


0214 


0215 


0216 


0217 


0218 


0219 


0220 


0221 


0222 


0223 


0E_ 


0224 


0225 


0226 


0227 


0228 


0229 


0230 


0231 


0232 


0233 


0234 


0235 


0236 


0237 


0238 


0239 


0F_ 


0240 


0241 


0242 


0243 


0244 


0245 


0246 


0247 


0248 


0249 


0250 


0251 


0252 


0253 


0254 


0255 


10_ 


0256 


0257 


0258 


0259 


0260 


0261 


0262 


0263 


0264 


0265 


0266 


0267 


0268 


0269 


0270 


0271 


11_ 


0272 


0273 


0274 


0275 


0276 


0277 


0278 


0279 


0280 


0281 


0282 


0283 


0284 


0285 


0286 


0287 


12_ 


0288 


0289 


0290 


0291 


0292 


0293 


0294 


0295 


0296 


0297 


0298 


0299 


0300 


0301 


0302 


0303 


13_ 


0304 


0305 


0306 


0307 


0308 


0309 


0310 


0311 


0312 


0313 


0314 


0315 


0316 


0317 


0318 


0319 


14_ 


0320 


0321 


0322 


0323 


0324 


0325 


0326 


0327 


0328 


0329 


0330 


0331 


0332 


0333 


0334 


0335 


15_ 


0336 


0337 


0338 


0339 


0340 


0341 


0342 


0343 


0344 


0345 


0346 


0347 


0348 


0349 


0350 


0351 


16_ 


0352 


0353 


0354 


0355 


0356 


0357 


0358 


0359 


0360 


0361 


0362 


0363 


0364 


0365 


0366 


0367 


17_ 


0368 


0369 


0370 


0371 


0372 


0373 


0374 


0375 


0376 


0377 


0378 


0379 


0380 


0381 


0382 


0383 


18_ 


0384 


0385 


0386 


0387 


0388 


0389 


0390 


0391 


0392 


0393 


0394 


0395 


0396 


0397 


0398 


0399 


19_ 


0400 


0401 


0402 


0403 


0404 


0405 


0406 


0407 


0408 


0409 


0410 


0411 


0412 


0413 


0414 


0415 


1A_ 


0416 


0417 


0418 


0419 


0420 


0421 


0422 


0423 


0424 


0425 


0426 


0427 


0428 


0429 


0430 


0431 


1B_ 


0432 


0433 


0434 


0435 


0436 


0437 


0438 


0439 


0440 


0441 


0442 


0443 


0444 


0445 


0446 


0447 


1C_ 


0448 


0449 


0450 


0451 


0452 


0453 


0454 


0455 


0456 


0457 


0458 


0459 


0460 


0461 


0462 


0463 


1D_ 


0464 


0465 


0466 


0467 


0468 


0469 


0470 


0471 


0472 


0473 


0474 


0475 


0476 


0477 


0478 


0479 


1E_ 


0480 


0481 


0482 


0483 


0484 


0485 


0486 


0487 


0488 


0489 


0490 


0491 


0492 


0493 


0494 


0495 


1F_ 


0496 


0497 


0498 


0499 


0500 


0501 


0502 


0503 


0504 


0505 


0506 


0507 


0508 


0509 


0510 


0511 
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1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


20_ 


0512 


0513 


0514 


0515 


0516 


0517 


0518 


0519 


0520 


0521 


0522 


0523 


0524 


0525 


0526 


0527 


21_ 


0528 


0529 


0530 


0531 


0532 


0533 


0534 


0535 


0536 


0537 


0538 


0539 


0540 


0541 


0542 


0543 


22„ 


0544 


0545 


0546 


0547 


0548 


0549 


0550 


0551 


0552 


0553 


0554 


0555 


0556 


0557 


0558 


0559 


23_ 


0560 


0561 


0562 


0563 


0564 


0565 


0566 


0567 


0568 


0569 


0570 


0571 


0572 


0573 


0574 


0575 


24_ 


0576 


0577 


0578 


0579 


0580 


0581 


0582 


0583 


0584 


0585 


0586 


0587 


0588 


0589 


0590 


0591 


25_ 


0592 


0593 


0594 


0595 


0596 


0597 


0598 


0599 


0600 


0601 


0602 


0603 


0604 


0605 


0606 


0607 


26_ 


0608 


0609 


0610 


0611 


0612 


0613 


0614 


0615 


0616 


0617 


0618 


0619 


0620 


0621 


0622 


0623 


27_. 


0624 


0625 


0626 


0627 


0628 


0629 


0630 


0631 


0632 


0633 


0634 


0635 


0636 


0637 


0638 


0639 


28_ 


0640 


0641 


0642 


0643 


0644 


0645 


0646 


0647 


0648 


0649 


0650 


0651 


0652 


0653 


0654 


0655 


29_ 


0656 


0657 


0658 


0659 


0660 


0661 


0662 


0663 


0664 


0665 


0666 


0667 


0668 


0669 


0670 


0671 


2A_ 


0672 


0673 


0674 


0675 


0676 


0677 


0678 


0679 


0680 


0681 


0682 


0683 


06^4 


0685 


0686 


0687 


2B„ 


0688 


0689 


0690 


0691 


0692 


0693 


0694 


0695 


0696 


0697 


0698 


0699 


0700 


0701 


0702 


0703 


2G_ 


0704 


0705 


0706 


0707 


0708 


0709 


0710 


0711 


0712 


0713 


0714 


0715 


0716 


0717 


0718 


0719 


2D_ 


0720 


0721 


0722 


0723 


0724 


0725 


0726 


0727 


0728 


0Y29 


0730 


0731 


0732 


0733 


0734 


0735 


2E_ 


0736 


0737 


0738 


0739 


0740 


0741 


0742 


0743 


0744 


0745 


0746 


0747 


0748 


0749 


0750 


0751 


2F_ 


0752 


0753 


0754 


0755 


0756 


0757 


0758 


0759 


0760 


0761 


0762 


0763 


0764 


0765 


0766 


0767 


30_ 


0768 


0769 


0770 


0771 


0772 


0773 


0774 


0775 


0776 


0777 


0778 


0779 


0780 


0781 


0782 


0783 


31_ 


0784 


0785 


0786 


0787 


0788 


0789 


0790 


0791 


0792 


0793 


0794 


0795 


0796 


0797 


0798 


0799 


32_ 


0800 


0801 


0802 


0803 


0804 


0805 


0806 


0807 


0808 


0809 


0810 


0811 


0812 


0813 


0814 


0815 


33_ 


0816 


0817 


0818 


0819 


0820 


0821 


0822 


0823 


0824 


0825 


0826 


0827 


0828 


0829 


0830 


0831 


34„ 


0832 


0833 


0834 


0835 


0836 


0837 


0838 


0839 


0840 


0841 


0842 


0843 


0844 


0845 


0846 


0847 


35_ 


0848 


0849 


0850 


0851 


0852 


0853 


0854 


0855 


0856 


0857 


0858 


0859 


0860 


0861 


0862 


0863 


36_ 


0864 


0865 


0866 


0867 


0868 


0869 


0870 


0871 


0872 


0873 


0874 


0875 


0876 


0877 


0878 


0879 


37_ 


0880 


0881 


0882 


0883 


0884 


0885 


0886 


0887 


0888 


0889 


0890 


0891 


0892 


0893 


0894 


0895 


38._ 


0896 


0897 


0898 


0899 


0900 


0901 


0902 


0903 


0904 


0905 


0906 


0907 


0908 


0909 


0910 


0911 


39_ 


0912 


0913 


0914 


0915 


0916 


0917 


0918 


0919 


0920 


0921 


0922 


0923 


0924 


0925 


0926 


0927 


3A_ 


0928 


0929 


0930 


0931 


0932 


0933 


0934 


0935 


0936 


0937 


0938 


0939 


0940 


0941 


0942 


0943 


3B._ 


0944 


0945 


0946 


0947 


0948 


0949 


0950 


0951 


0952 


0953 


0954 


0955 


0956 


0957 


0958 


0959 


3C_ 


0960 


0961 


0962 


0963 


0964 


0965 


0966 


0967 


0968 


0969 


0970 


0971 


0972 


0973 


0974 


0975 


3D_ 


0976 


0977 


0978 


0979 


0980 


0981 


0982 


0983 


0984 


0985 


0986 


0987 


0988 


0989 


0990 


0991 


3E_ 


0992 


0993 


0994 


0995 


0996 


0997 


0998 


0999 


1000 


1001 


1002 


1003 


1004 


1005 


1006 


1007 


3F_ 


1008 


1009 


1010 


1011 


1012 


1013 


1014 


1015 


1016 


1017 


1018 


1019 


1020 


1021 


1022 


1023 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


40_ 


1024 


1025 


1026 


1027 


1028 


1029 


1030 


1031 


1032 


1033 


1034 


1035 


1036 


1037 


1038 


1039 


41_ 


1040 


1041 


1042 


1043 


1044 


1045 


1046 


1047 


1048 


1049 


1050 


1051 


1052 


1053 


1054 


1055 


42_ 


1056 


1057 


1058 


1059 


1060 


1061 


1062 


1063 


1064 


1065 


1066 


1067 


1068 


1069 


1070 


1071 


43_ 


1072 


1073 


1074 


1075 


1076 


1077 


1078 


1079 


1080 


1081 


1082 


1083 


1084 


1085 


1086 


1087 


44_ 


1088 


1089 


1090 


1091 


1092 


1093 


1094 


1095 


1096 


1097 


1098 


1099 


1100 


1101 


1102 


1103 


45_ 


1104 


1105 


1106 


1107 


1108 


1109 


1110 


nil 


1112 


1113 


1114 


1115 


1116 


1117 


1118 


1119 


46_ 


1120 


1121 


1122 


1123 


1124 


1125 


1126 


1127 


1128 


1129 


1130 


1131 


1132 


1133 


1134 


1135 


47_ 


1136 


1137 


1138 


1139 


1140 


1141 


1142 


1143 


1144 


1145 


1146 


1147 


1148 


1149 


1150 
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2994 


2995 


2996 


2997 


2998 


2999 


3000 


3001 


3002 


3003 


3004 


3005 


3006 


3007 


BC_ 


3008 


3009 


3010 


3011 


3012 


3013 


3014 


3015 


3016 


3017 


3018 


3019 


3020 


3021 


3022 


3023 


BD_ 


3024 


3025 


3026 


3027 


3028 


3029 


3030 


3031 


3032 


3033 


3034 


3035 


3036 


3037 


3038 


3039 


BE_ 


3040 


3041 


3042 


3043 


3044 


3045 


3046 


3047 


3048 


3049 


3050 


3051 


3052 


3053 


3054 


3055 


BF_ 


3056 


3057 


3058 


3059 


3060 


3061 


3062 


3063 


3064 


3065 


3066 


3067 


3068 


3069 


3070 


3071 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


C0_ 


3072 


3073 


3074 


3075 


3076 


3077 


3078 


3079 


3080 


3081 


3082 


3083 


3084 


3085 


3086 


3087 


Cl_ 


3088 


3089 


3090 


3091 


3092 


3093 


3094 


3095 


3096 


3097 


3098 


3099 


3100 


3101 


3102 


3103 


C2_ 


3104 


3105 


3106 


3107 


3108 


3109 


3110 


3111 


3112 


3113 


3114 


3115 


3116 


3117 


3118 


3119 


C3_ 


3120 


3121 


3122 


3123 


3124 


3125 


3126 


3127 


3128 


3129 


3130 


3131 


3132 


3133 


3134 


3135 


C4_ 


3136 


3137 


3138 


3139 


3140 


3141 


3142 


3143 


3144 


3145 


3146 


3147 


3148 


3149 


3150 


3151 


C5_ 


3152 


3153 


3154 


3155 


3156 


3157 


3158 


3159 


3160 


3161 


3162 


3163 


3164 


3165 


3166 


3167 


C6 


3168 


3169 


3170 


3171 


3172 


3173 


3174 


3175 


3176 


3177 


3178 


3179 


3180 


3181 


3182 


3183 


C7_ 


3184 


3185 


3186 


3187 


3188 


3189 


3190 


3191 


3192 


3193 


3194 


3195 


3196 


3197 


3198 


3199 


C8_ 


3200 


3201 


3202 


3203 


3204 


3205 


3206 


3207 


3208 


3209 


3210 


3211 


3212 


3213 


3214 


3215 


C9_ 


3216 


3217 


3218 


3219 


3220 


3221 


3222 


3223 


3224 


3225 


3226 


3227 


3228 


3229 


3230 


3231 


CA_ 


3232 


3233 


3234 


3235 


3236 


3237 


3238 


3239 


3240 


3241 


3242 


3243 


3244 


3245 


3246 


3247 


CB_ 


3248 


3249 


3250 


3251 


3252 


3253 


3254 


3255 


3256 


3257 


3258 


3259 


3260 


3261 


3262 


3263 


cc_ 


3264 


3265 


3266 


3267 


3268 


3269 


3270 


3271 


3272 


3273 


3274 


3275 


3276 


3277 


3278 


3279 


CD 


3280 


3281 


3282 


3283 


3284 


3285 


3286 


3287 


3288 


3289 


3290 


3291 


3292 


3293 


3294 


3295 


CE_ 


3296 


3297 


3298 


3299 


3300 


3301 


3302 


3303 


3304 


3305 


3306 


3307 


3308 


3309 


3310 


3311 


CF_ 


3312 


3313 


3314 


3315 


3316 


3317 


3318 


3319 


3320 


3321 


3322 


3323 


3324 


3325 


3326 


3327 


D0_ 


3328 


3329 


3330 


3331 


3332 


3333 


3334 


3335 


3336 


3337 


3338 


3339 


3340 


3341 


3342 


3343 


Dl_ 


3344 


3345 


3346 


3347 


3348 


3349 


3350 


3351 


3352 


3353 


3354 


3355 


3356 


3357 


3358 


3359 


D2_ 


3360 


3361 


3362 


3363 


3364 


3365 


3366 


3367 


3368 


3369 


3370 


3371 


3372 


3373 


3374 


3375 


D3_ 


3376 


3377 


3378 


3379 


3380 


3381 


3382 


3383 


3384 


3385 


3386 


3387 


3388 


3389 


3390 


3391 


D4_ 


3392 


3393 


3394 


3395 


3396 


3397 


3398 


3399 


3400 


3401 


3402 


3403 


3404 


3405 


3406 


3407 


D5_ 


»408 


3409 


3410 


3411 


3412 


3413 


3414 


3415 


3416 


3417 


3418 


3419 


3420 


3421 


3422 


3423 


D6_ 


3424 


3425 


3426 


3427 


3428 


3429 


3430 


3431 


3432 


3433 


3434 


3435 


3436 


3437 


3438 


3439 


D7._ 


3440 


3441 


3442 


3443 


3444 


3445 


3446 


3447 


3448 


3449 


3450 


3451 


3452 


3453 


3454 


3455 


D8_ 


3456 


3457 


3458 


3459 


3460 


3461 


3462 


3463 


3464 


3465 


3466 


3467 


3468 


3469 


3470 


3471 


D9_ 


3472 


3473 


3474 


3475 


3476 


3477 


3478 


3479 


3480 


3481 


3482 


3483 


3484 


3485 


3486 


3487 


DA_ 


3488 


3489 


3490 


3491 


3492 


3493 


3494 


3495 


3496 


3497 


3498 


3499 


3500 


3501 


3502 


3503 


DB_ 


3504 


3505 


3506 


3507 


3508 


3509 


3510 


3511 


3512 


3513 


3514 


3515 


3516 


3517 


3518 


3519 


DC„ 


3520 


3521 


3522 


3523 


3524 


3525 


3526 


3527 


3528 


3529 


3530 


3531 


3532 


3533 


3534 


3535 


DD_ 


3536 


3537 


3538 


3539 


3540 


3541 


3542 


3543 


3544 


3545 


3546 


3547 


3548 


3549 


3550 


3551 


DE_ 


3552 


3553 


3554 


3555 


3556 


3557 


3558 


3559 


3560 


3561 


3562 


3563 


3564 


3565 


3566 


3567 


DF_ 


3568 


3569 


3570 


3571 


3572 


3573 


3574 


3575 


3576 


3577 


3578 


3579 


3580 


3581 


3582 


3583 



144 








1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


E0_ 


3584 


3585 


3586 


3587 


3583 


3589 


3590 


3591 


3592 


3593 


3594 


3595 


3596 


3597 


3598 


3599 


El_ 


3600 


3601 


3602 


3603 


3604 


3605 


3606 


3607 


3608 


3609 


3610 


3611 


3612 


3613 


3614 


3615 


E2_ 


3616 


3617 


3618 


3619 


3620 


3621 


3622 


3623 


3624 


3625 


3626 


3627 


3628 


3629 


3630 


3631 


E3_ 


3632 


3633 


3634 


3635 


3636 


3637 


3638 


3639 


3640 


3641 


3642 


3643 


3644 


3645 


3646 


3647 


E4_ 


3648 


3649 


3650 


3651 


3652 


3653 


3654 


3655 


3656 


3657 


3658 


3659 


3660 


3661 


3662 


3663 


E5_ 


3664 


3665 


3666 


3667 


3668 


3669 


3670 


3671 


3672 


3673 


3674 


3675 


3676 


3677 


3678 


3679 


E6 


3680 


3681 


3682 


3683 


3684 


3685 


3686 


3687 


3688 


3689 


3690 


3691 


3692 


3693 


3694 


3695 


E7_ 


3696 


3697 


3698 


3699 


3700 


3701 


3702 


3703 


3704 


3705 


3706 


3707 


3708 


'3709 


3710 


3711 


E8 


3712 


3713 


3714 


3715 


3716 


3717 


3718 


3719 


3720 


3721 


3722 


3723 


3724 


3725 


3726 


3727 


E9_ 


3728 


3729 


3730 


3731 


3732 


3733 


3734 


3735 


3736 


3737 


3738 


3739 


3740 


3741 


3742 


3743 


EA_ 


3744 


3745 


3746 


3747 


3748 


3749 


3750 


3751 


3752 


3753 


3754 


3755 


3756 


3757 


3758 


3759 


EB_ 


3760 


3761 


3762 


3763 


3764 


3765 


3766 


3767 


3768 


3769 


3770 


3771 


3772 


3773 


3774 


3775 


EC_ 


3776 


3777 


3778 


3779 


3780 


3781 


3782 


3783 


3784 


3785 


3786 


3787 


3788 


3789 


3790 


3791 


ED_ 


3792 


3793 


3794 


3795 


3796 


3797 


3798 


3799 


3800 


3801 


3802 


3803 


3804 


3805 


3806 


3807 


EE_ 


3808 


3809 


3810 


3811 


3812 


3813 


3814 


3815 


3816 


3817 


3818 


3819 


3820 


3821 


3822 


3823 


EF_ 


3824 


3825 


3826 


3827 


3828 


3829 


3830 


3831 


3832 


3833 


3834 


3835 


3836 


3837 


3838 


3839 


F0_ 


3840 


3841 


3842 


3843 


3844 


3845 


3846 


3847 


3848 


3849 


3850 


3851 


3852 


3853 


3854 


3855 


Fl_ 


3856 


3857 


3858 


3859 


3860 


3861 


3862 


3863 


3864 


3865 


3866 


3867 


3868 


3869 


3870 


3871 


F2_ 


3872 


3873 


3874 


3875 


3876 


3877 


3878 


3879 


3880 


3881 


3882 


3883 


3884 


3885 


3886 


3887 


F3_ 


3888 


3889 


3890 


3891 


3892 


3893 


3894 


3895 


3896 


3897 


3898 


3899 


3900 


3901 


3902 


3903 


F4_ 


3904 


3905 


3906 


3907 


3908 


3909 


3910 


3911 


3912 


3913 


3914 


3915 


3916 


3917 


3918 


3919 


F5_ 


3920 


3921 


3922 


3923 


3924 


3925 


3926 


3927 


3928 


3929 


3930 


3931 


3932 


3933 


3934 


3935 


F6_ 


3936 


3937 


3938 


3939 


3940 


3941 


3942 


3943 


3944 


3945 


3946 


3947 


3948 


3949 


3950 


3951 


F7_ 


3952 


3953 


3954 


3955 


3956 


3957 


3958 


3959 


3960 


3961 


3962 


3963 


3964 


3965 


3966 


3967 


F8_ 


3968 


3969 


3970 


3971 


3972 


3973 


3974 


3975 


3976 


3977 


3978 


3979 


3980 


3981 


3982 


3983 


F9_ 


3984 


3985 


3986 


3987 


3988 


3989 


3990 


3991 


3992 


3993 


3994 


3995 


3996 


3997 


3998 


3999 


FA_ 


4000 


4001 


4002 


4003 


4004 


4005 


4006 


4007 


4008 


4009 


4010 


4011 


4012 


4013 


4014 


4015 


FB_ 


4016 


4017 


4018 


4019 


4020 


4021 


4022 


4023 


4024 


4025 


4026 


4027 


4028 


4029 


4030 


4031 


FC_ 


4032 


4033 


4034 


4035 


4036 


4037 


4038 


4039 


4040 


4041 


4042 


4043 


4044 


4045 


4046 


4047 


FD_ 


4048 


4049 


4050 


4051 


4052 


4053 


4054 


4055 


4056 


4057 


4058 


4059 


4060 


4061 


4062 


4063 


FE_ 


4064 


4065 


4066 


4067 


4068 


4069 


4070 


4071 


4072 


4073 


4074 


4075 


4076 


4077 


4078 


4079 


FF_ 


4080 


4081 


4082 


4083 


4084 


4085 


4086 


4087 


4088 


4089 


4090 


4091 


4092 


4093 


4094 


4095 
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Hexadecimal and Decimal Integer Conversion Table 



HALFWORD 


HALFWORD | 


BYTE 


BYTE 


BYTE 


.BYTE 


BITS: 0123 


4567 


0123 


4567 


0123 


4567 


0123 


4567 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


Hex 


Decimal 


















































1 


268,435,456 


1 


16,777,216 


1 


1,048,576 


1 


65,536 


1 


4,096 


1 


256 


1 


16 


1 


f 


2 


53&, 870,91 2 


2 


33,554,432 


2 


2,097,152 


2 


131,072 


2 


8,192 


2 


512 


2 


32 


2 


2 


3 


605,306,368 


3 


50,331,648 


3 


3,145^28 


3 


196,608 


3 


12,288 




768 


3 


48 


3 


3 


4 


1,073,741,824 


4 


67,108,864 


4 


4.194,304 


4 


262,144 


4 


16,384 


4 


1,024 


4 


64 


4 


4 


5 


1,342,177,280 


5 


83,886,080 


5 


5,242,880 


5 


327,680 


5 


20,480 


5 


1,280 


5 


80 


5 


5 


6 


1,610,612,736 


6 


100,663,296 


6 


6,291,456 


6 


393,216 


6 


24,576 


6 


1,536 


6 


96 


6 


6 


7 


1,879,048,192 


7 


117,440,512 


7 


7,340,032 


7 


458,752 


7 


28,672 


7 


1,792 


7 


112 


7 


7 


8 


2,147,483,648 


8 


134,217,728 


8 


8,388,608 


8 


524,288 


8 


32,768 


8 


2,048 


8 


128 


8 


8 


$ 


2,415,919,104 


9 


150,994,944 


9 


9,437,184 


9 


589,824 


9 


36,864 


9 


2,304 


9 


144 


9 


9 


A 


2,684,354,560 


A 


167,772,160 


A 


10,485,760 


A 


655,360 


A 


40,960 


A 


2,560 


A 


160 


A 


10 


B 


2,952,790,016 


B 


184,549,376 


B 


11,534,336 


B 


720,896 


B 


45.056 


B 


2.816 


B 


176 


B 


n 


C 


3,221,225,472 


C 


201,326,592 


C 


12,582,912 


C 


786,432 


C 


49.152 


C 


3,072 


C 


192 


C 


12 


D 


3,489,660,928 


D 


218,103,808 


D 


13,631,488 


D 


851,968 


D 


53,248 


D 


3,328 


D 


208 


D 


13 


E 


3,758,096,384 


E 


234,881,024 


E 


14,680,064 


E 


917,504 


E 


57,344 


E 


3,584 


E 


224 


E 


14 


F 


4,026,531,840 


F 


251,658,240 


F 


15,728,640 


F 


983,040 


, F 


61,440 


F 


3,840 


F 


240 


F 


15 


8 


7 


6 


5 


* 


3 


2 


" "' 1 



TO CONVERT HEXADECIMAL TO DECIMAL 

1 . Locate the column of decimal numbers corresponding to 
the left-most digit or letter of the hexadecimal; select 
from this column and record the number that corresponds 
to the position of the hexadecimal digit or letter. 

2. Repeat step 1 for the next (second from the left) 
position . 

3. Repeat step 1 for the units (third from the left) 
position. 

4. Add the numbers selected from the table to form the 
decimal number. 



TO CONVERT DECIMAL TO HEXADECIMA L 

1 . (a) Select from the table the highest decimal number 
that is equal to or less than the number to be con- 
verted . 

(b) Record the hexadecimal of the column containing 
the selected number. 

(c) Subtract the selected decimal from the number to 
be converted. 

2. Using the remainder from step 1(c) repeat all of step 1 
to develop the second position of the hexadecimal 
(and a remainder) . 

3. Using the remainder from step 2 repeat all of step 1 to 
develop the units p>osition of the hexadecimal . 

4. Combine terms to form the hexodecimal number. 



EXAMPLE 




Conversion of 




Hexadecimal Value 


D34 


1. D 


3328 


2. 3 


48 


3. 4 


4 


4. Decimal 


3380 



EXAMPLE 




Conversion of 
Decimal Value 


3380 


1. D 


-3328 
52 


2. 3 


-48 

4 


3. 4 


-4 


4. Hexadecimal 


D34 



To convert integer numbers greater than the capacity of 
table, use the techniques below: 

HEXADECIMAL TO DECIMAL 

Successive cumulative multiplication from left to right, 
adding units position. 



Example: D34]5 = 3380^q 




3380 



DECIMAL TO HEXADECIMAL 



Divide and collect the remainder in reverse order. 



Example: 3380, «= X,. 

16 I 3380 . .^ 
16 [211 . ^ ^ 
16 I 13 .^ 



remainder 

4 

3 

D 



3380io = D34,^ 



POWERS OF 16 TABLE 

Example: 268,435, 456,q = (2.68435456 x 10^), q = 1000 0000, ^ = 00^)^ 



16" 


n 


1 





16 


1 


256 


2 


4 096 


3 


65 536 


4 


1 048 576 


5 


16 777 216 


6 


268 435 456 


7 


4 294 967 296 


8 


68 719 476 736 


9 


1 099 511 627 776 


10 = A 


17 592 186 044 416 


11 =B 


281 474 976 710 656 


12=C 


4 503 599 627 370 496 


13 = D 


72 057 594 037 927 936 


14 = E 


J 152 921 504 606 846 976 


15 = F 



Decimal Values 
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Hexadecimal and Decimal Fraction Conversion Table 



HALFWORD | 


BYTE 


BYTE 1 


BITS 


0123 


4567 


0123 


4567 


Hex 


Decimal 


■iex 


Decimal 


Hex 


Decimal 


Hex 




Decima 


Equivalent 




.0 


.0000 


00 


.0000 


0000 


.000 


.0000 


0000 


0000 


.0000 


.0000 


0000 


0000 


0000 


.1 


.0625 


01 


.0039 


0625 


.001 


.0002 


4414 


0625 


.0001 


.0000 


1525 


8789 


0625 


.2 


.1250 


02 


.0078 


1250 


.002 


.0004 


8828 


li50 


.0002 


.0000 


3051 


7578 


t250 


.3 


.1875 


03 


.0117 


1875 


.003 


.0007 


3242 


1875 


.0003 


.0000 


4577 


6367 


1875 


.4 


.2500 


04 


.0156 


2500 


.004 


.0009 


7656 


2500 


.0004 


.0000 


6103 


5156 


2500 


.5 


.3125 


05 


.0195 


3125 


.005 


.0012 


2070 


3125 


.0005 


.0000 


7629 


3945 


3125 


.6 


.3750 


06 


.0234 


3750 


.006 


.0014 


6484 


3750 


.0006 


.0000 


9155 


2734 


3750 


.7 


.4375 


07 


.0273 


4375 


.007 


.0017 


0898 


4375 


.0007 


.0001 


0681 


1523 


4375 


.8 


.5000 


08 


.0312 


5000 


.008 


.0019 


5312 


5000 


.0008 


.0001 


2267 


031 2 


5000 


.9 


.5625 


09 


.0351 


5625 


.009 


.0021 


9726 


5625 


,0009 


.0001 


3732 


9101 


5625 


.A 


.6250 


OA 


.0390 


6250 


.00 A 


.0024 


4140 


6250 


.OOOA 


.0001 


5258 


7890 


6250 


.B 


.6875 


OB 


.0429 


6875 


.OOB 


.0026 


8554 


6875 


.OOOB 


.0001 


6784 


6679 


6875 


.C 


.7500 


OC 


.0468 


7500 


.OOC 


.0029 


2968 


7500 


.OOOC 


.0001 


8310 


5468 


7500 


.D 


.8125 


OD 


.0507 


8125 


.OOD 


.0031 


7382 


8125 


.OOOD 


.0001 


9836 


4257 


8125 


.E 


.8750 


OE 


.0546 


8750 


.OOE 


.0034 


1796 


8750 


.OOOE 


.0002 


1362 


3046 


8750 


.F 


.9375 


OF 


.0585 


9375 


.OOF 


.0036 


6210 


9375 


.OOOF 


.0002 


2888 


1835 


9375 


1 


2 


3 


1 



TO CONVERT .ABC HEXADECIMAL TO DECIMAL 

Find .A in position 1 .6250 

Find .OB in position 2 .0429 6875 

Find .OOC in position 3 .0029 2968 7500 

.ABC Hex is equal to .6708 9843 7500 

TO CONVERT .13 DECIMAL TO HEXADECIMAL 



To convert fractions beyond the capacity of table, use techniques below: 



HEXADECIMAL FRACTION TO DECIMAL 

Convert the hexadecimal fraction to its decimal equivalent using the same 
technique as for integer numbers. Divide the results by 16*^ (n is the 
number of fraction positions). 
Example: .8A7 =. 54077) jq 



8A7,6 = 221510 

163 = 4096 409612215.000000 



.540771 



Find .1250 next lowest to 
subtract 



2. Find .0039 0625 next lowest to 

3. Find .0009 7656 2500 

4. Find .0001 0681 1523 4375 



5. 13 Decimal is approximately equal to- 



.1300 
-.1250 


= ,2 Hex 




.0050 0000 
-.0039 0625 


= .01 


DECIMAL FRACTION TO HEXADECIMAL 


.0010 9375 0000 
-.0009 7656 2500 

.0001 1718 7500 0000 
-.0001 0681 1523 4375 


= .004 
- .0007 


Collect integer parts of product in the order of calculation 

Example: .5408io = .8A7i6 

.5408 
xl6 


.0000 1037 5976 5625 


» .21 47 Hex 
4 


8 -<- |_8|.6528 

A-<- |l0|.4448 

x16 

'7 -*- [71.1168 




1 
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Hexadecimal Add 
Example: 6 + 2 = 



ifion and Subtraction Table 
8, 8-2=6, and 8-6 = 2 





1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


1 


02 


03 


04 


05 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


2 


03 


04 


05 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


3 


04 


05 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


4 


05 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


5 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


6 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


7 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


8 


09 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


9 


OA 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


A 


OB 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


B 


OC 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


lA 


C 


OD 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


lA 


IB 


D 


OE 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


IC 


E 


OF 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


IC 


ID 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


1C 


ID 


IE 



Hexadecimal Multipli 
Example: 2x4 = 08, 



cation Table 
Fx2= IE 





1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


1 


01 


02 


03 


04 


05 


06 


07 


08 


09 


OA 


OB 


OC 


OD 


OE 


OF 


2 


02 


04 


06 


08 


OA 


OC 


OE 


10 


12 


14 


16 


18 


lA 


IC 


IE 


3 


03 


06 


09 


OC 


OF 


12 


15 


18 


IB 


IE 


21 


24 


27 


2A 


2D 


4 


04 


08 


OC 


10 


14 


18 


IC 


20 


24 


28 


2C 


30 


34 


38 


3C 


5 


05 


OA 


OF 


14 


19 


IE 


23 


28 


2D 


32 


37 


3C 


41 


46 


4B 


6 


06 


OC 


12 


18 


IE 


24 


2A 


30 


36 


3C 


42 


48 


4E 


54 


5A 


7 


07 


OE 


15 


IC 


23 


2A 


31 


38 


3F 


46 


4D 


54 


5B 


62 


69 


8 


08 


10 


18 


20 


28 


30 


38 


40 


48 


50 


58 


60 


68 


70 


78 


9 


09 


12 


IB 


24 


2D 


36 


3F 


48 


51 


5A 


63 


6C 


75 


7E 


87 


A 


OA 


14 


IE 


28 


32 


3C 


46 


50 


5A 


64 


6E 


78 


82 


8C 


96 


B 


OB 


16 


21 


2C 


37 


42 


4D 


58 


63 


6E 


79 


84 


8F 


9A 


A5 


C 


OC 


18 


24 


30 


3C 


48 


54 


60 


6C 


78 


84 


90 


9C 


A8 


B4 


D 


OD 


1A 


27 


34 


41 


4E 


5B 


68 


lb 


82 


8F 


9C 


A9 


B6 


C3 


E 


OE 


IC 


2A 


38 


46 


54 


62 


70 


7E 


8C 


9A 


A8 


B6 


C4 


D2 


F 


OF 


IE 


2D 


3C 


4B 


5A 


69 


78 


87 


96 


A5 


B4 


C3 


D2 


El 
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Appendix F. USASCII-S and EBCDIC Charts 



Charts and supporting text appear on the following 
pages. 
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By TNL N22-0244 

Code Structures 

Both usAscn-8 and ebcdic provide for 256 possible 
characters. Each character is composed of eight bits 
(one byte), and each bit position is assigned a num- 
ber. The bit positions are numbered as follows: 



I I I I I I I 



USASCII-8 87654321 
EBCDIC 01234567 

USA Standard Code for Information Interchange 
(USASCII) Embedded in USASCII-8 

The seven-bit usascii has its bits numbered as follovi's: 



_L__I I I I L 



USASCII b7 be U hi bs b2 bi 

The seven-bit usAScn can be extended to eight !bits 
and embedded in usAScn-8 as follovi's: 



I I I I l_l L 



USASCII by be b? bs b4 bs b2 bi 
USASCII-8 87654321 

The 256-position table at the right, outlined by the 

heavy black lines, shows the graphic characters and 

control character representations for usAScn-8. The 

bit-position numbers, bit patterns, and hexadecimal 

representations for these and other possible usascii-b 

characters are also shown. 
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I g 


00 


01 


10 


1 


S tA 


00 


01 


10 


11 


00 


01 


10 


11 


00 


01 


10 


11 


00 


01 


10 


11 







1 


2 


3 


4 


5 


6 


7 


8 


9 


A 


B 


c 


D 


E 


F 


0000 





NUL 


DLE 






SP 













@ 


P 






> 


P 


0001 


1 


SOH 


DCl 






.(D 


1 










A 


Q 






a 


q 


0010 


2 


STX 


DC2 






" 


2 










B 


R 






b 


r 


0011 


3 


ETX 


DC3 






* 


3 










>-.^' 


S 






c 


s 


0100 


4 


EOT 


DC4 






$ 


4 










D 


T 






d 


t 


0101 


5 


ENQ 


NAK 






% 


5 










i E , 


U 






e 


u 


Olio 


6 


ACK 


SYN 






& 


6 










F 


V 






f 


V 


0111 


7 


BEL 


ETB 






■ 


7 










G 


W 






g 


w 


1000 


8 


BS 


CAN 






( 


8 










H 


X 






h 


X 


1001 


9 


HT 


EM 






) 


9 










1 


Y 






i 


y 


1010 


A 


LF 


SUB 






* 












J 


Z 






i 


z 


1011 


B 


VT 


ESC 






+ 


! 










K 


[ 






k 


{ 


1100 


C 


FF 


FS 






r 


< 










L 


\ 






1 


1 
1 


1101 


D 


CR 


GS 






- 


= 










M 


] 






m 


} 


1110 


E 


SO 


RS 








> 










N 


A® 






n 


" 


nil 


F 


SI 


US 






/ 


? 










O 









o 


DEL 



} Bit Positions 8, 7 
I Bit Positions 6, 5 

First Hexadecimal Digit 



(T) In the event that IBM equipment implementing USASCII-8 is provided, the graphic |(Loglcal OR) will be used 
instead of I (Exclamation Point). 

(2) In the event that IBM equipment implementing USASCII-8 is provided, the graphic I (Logical NOT) will be 
used instead of A (Circumflex). 

Note: Current activities in committees under the auspices of the United States of America Standards Institute may result 
in changes to the character's and/or structure of the eight-bit representation of USASCll devised by the Institute. 
Such changes may cause the eight-bit representation of USASCll implemented in System/360 (USASCII-8) to be 
different from a future USA Standard. Since a difference of this nature may eventually lead to a modification of 
System/360, it is recommended that users avoid: (1) operation with PSW bit 12 set to 1, and (2) the use of any 
sign codes in decimal data other than those preferred for EBCDIC. 



Control Character Representations 



Special Graphic Characters 



NUL 


Null 


DLE 


SOH 


Start of Heading (CC) 


DCl 


STX 


Start of Text (CC) 


DC2 


ETX 


End of Text (CC) 


DC3 


EOT 


End of Transmission (CC) 


DC4 


ENQ 


Enquiry (CC) 


NAK 


ACK 


Acknowledge (CC) 


SYN 


BEL 


Bell 


ETB 


BS 


Backspace (FE) 


CAN 


HT 


Horizontal Tabulation (FE) 


EM 


LF 


Line Feed (FE) 


SUB 


VT 


Vertical Tabulation (FE) 


ESC 


FF 


Form Feed (FE) 


FS 


CR 


Carriage Return (FE) 


GS 


SO 


Shift Out 


RS 


SI 


Shift In 


US 
DEL 


(CC) 


Communication Control 




(FE) 


Format Effector 




(IS) 


Information Separator 





Data Link Escape (CC) 

Device Control 1 

Device Control 2 

Device Control 3 

Device Control 4 

Negative Acknowledge (CC) 

Synchronous Idle (CC) 

End of Transmission Block (CC) 

Cancel 

End of Medium 

Substitute 

Escape 

File Separator (IS) 

Group Separator (IS) 

Record Separator (IS) 

Unit Separator (IS) 

Delete 



SP 


Space 


< 


Less Than 


I 


Exclamation Point 


= 


Equals 


1 


Logical OR 


> 


Greater Than 


11 


Quotation Marks 


? 


Question Mark 


# 


Number Sign 


@ 


Commercial At 


$ 


Dollar Sign 


L 


Opening Bracket 


% 


Percent 


\ 


Reverse Slant 


& 


Ampersand 


1 


Closing Bracket 


' 


Apostrophe 


A 


Circumflex 


( 


Opening Parenthesis 


— 1 


Logical NOT 


) 


Closing Parenthesis 





Underline 




Asterisk 


N. 


Grave Accent 


+ 


Plus 


{ 


Opening Brace 


, 


Comma 


1 
1 


Vertical Line (This graphic is 


- 


Hyphen (Minus) 




stylized to distinguish it from 




Period (Decimal Point) 




Logical OR) 


/ 


Slant 


1 


Closing Brace 




Colon 




Tilde 


; 


Semicolon 
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Extended Binary-Coded-Decimal Interchange Code 
(EBCDIC) 

The 256-position table at the right, outhned by the 
heavy black Unes, shows the graphic characters and 
control character representations for ebcdic. The bit- 
position numbers, bit patterns, hexadecimal represen- 
tations and card hole patterns for these and other pos- 
sible EBCDIC characters are also shown. 

To find the card hole patterns for most characters, 
partition the 256-position table into four blocks as 
follows: 

Block 1: Zone punches at top of table; 

digit punches at left 
Block 2: Zone punches at bottom of table; 

digit punches at left 
Block 3: Zone punches at top of table; 

digit punches at right 
Block 4: Zone punches at bottom of table; 

digit punches at right 

Fifteen positions in the table are exceptions to the 
above arrangement. These positions are indicated by 
small numbers in the upper right comers of their boxes 
in the table. The card hole patterns for these positions 
are given at the bottom of the table. Bit-position num- 
bers, bit patterns, and hexadecimal representations for 
these positions are found in the usual manner. 

Following are some examples of the use of the 
EBCDIC chart: 



2 4 



Character 


Type 


Bit Pattern 


Hex 


Hole Pattern 


Zone Punches 


Digi 


Punches 


PF 


Control Character 


00 00 0100 


04 


12-9 


-4 


% 


Special Graphic 


01 10 1100 


6C 


"0^-8- 


4 


R 


Upper Case 


11 01 1001 


D9 


■ ~ ITP 9 


a 


Lower Case 


10 00 0001 


81 


12-01- 1 




Control Character, 
function not yet 
assigned 


00 1 1 0000 


30 


12-11-0-91-3-1 

1 

1 



Bit Positions 
01 23 4567 
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NUL 



^ 



DS 



(5 



© 










® 



(!!) 



® 



I Bit Positions 0,1 
1 Bit Positions 2,3 
I First Hexadecimal Digit 

Zone Punches 

Digit Punches 



® 



0010 



0100 



TES 



BYP 



PN 



0101 



NL 



® 



0111 



1000 



1010 



8-2 



® 



8-S 



8-4 



8-5 



1110 



nil F 8-7 






?'!': 



.:i2» 



';f;:]:Z,-.. 



.:::i|'^ 



,;=:«: 



:i3;;: 



Zone Punches 



Cord Hole Patterns 






® 


12-0-9-8-1 




(S) No Punches 


® 


12-11-9-8-1 




(6) 12 


0) 


11-0-9-8-1 




© n 


® 


12-11-0-9-8-1 




(S) 12-11-0 


Control Character Representations 




NUL 


Null 


SOS 


Start of Significance 


PF 


Punch Off 


FS 


Field Separator 


HT 


Horizontal Tab 


BYP 


Bypass 


LC 


Lower Case 


LF 


Line Feed 


DEL 


Delete 


EOB 


End of Block 


TM 


Tape Mark 


PRE 


Prefix 


RES 
NL 
BS 


Restore 
New Line 
Backspace 


SM 
PN 
RS 


Set Mode 
Punch On 
Reader Stop 


IL 
CC 
DS 


Idle 

Cursor Control 

Digit Select 


UC 

EOT 

SP 


Upper Case 

End of Transmission 

Space 



® 12-0 
(jo) 11-0 
(jj) 0-8-2 

® ° 

Special Graphic Characters 

<; Cent Sign 

Period, Decimal Point 
< Less-than Sign 
( Left Parenthesis 
+ Plus Sign 
I Logical OR 
& Ampersand 
I Exclamation Point 
$ Dollar Sign 
* Asterisk 
) Right Parenthesis 
; Semicolon 
1 Logical NOT 



® 0-1 
(J4) 11-0-9-1 

(J5) 12-11 



Minus Sign, Hyphen 

Slash 

Comma 

Percent 

Underscore 

Greater-than Sign 

Question Mark 

Colon 

Number Sign 

At Sign 

Prime, Apostrophe 

Equal Sign 

Quotation Mark 
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Appendix G. Formats and Tables 



Data Formats 

Fixed-Point Numbers 

Full Word Fixed-Point Number 



Integer 



Halfword Fixed-Point Nunther 



Integer 



Floating-Point Numbers 
Short Floating-Point Number 



s 


Characteristic 


Fraction 



Hexadecimal Representation 



HEXADECIMAL 


PRINTED 


EBCDIC* 


ASCII-8t 


CODE 


GRAPHIC 


CODE 


CODE 


0000 


] 


Llll 0000 


0101 0000 


0001 


1 ] 


Llll 0001 


0101 0001 


0010 


2 ] 


Llll 0010 


0101 0010 


0011 


3 ] 


Llll 0011 


0101 0011 


0100 


4 ] 


Llll 0100 


0101 0100 


0101 


5 ] 


Llll 0101 


0101 0101 


Olio 


6 ] 


Llll 0110 


01010110 


0111 


7 ] 


Llll 0111 


01010111 


1000 


8 ] 


Llll 1000 


0101 1000 


1001 


9 ] 


Llll 1001 


0101 1001 


1010 


A ] 


L 100 0001 


1010 0001 


1011 


B ] 


LlOOOOlO 


1010 0010 


1100 


C ] 


LIOOOOll 


1010 0011 


1101 


D ] 


LlOOOlOO 


1010 0100 


1110 


E ] 


LlOOOlOl 


1010 0101 


1111 


F ] 


LlOOOllO 


1010 0110 



''Extended Binary-Coded-Decimal Interchange Code. 
fAn eight-bit representation for American Standard Code for 
Information Interchange for use in eight-bit environments. 



long Floating-Point Number 



s 


characteristic 


Fraction yi 



Decimal Numbers 
Packed Decimal Number 



Digit 


Digit 


Digit 



Digit 


Digit 


Digit 


Digit 


Sign 



Zoned Decimal Number 



Zone 


Digit 


Zone 



Digit 


Zone 


Digit 


Sign 


Digit 



Logical Information 
Fixed-Length Logical Information 



Logical Data 



Variable-Length Logical Information 



Character 


Character 



Character 
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Instructions by Format Type 
RR Format 



RS Format 



Op Code 


^1 


"2 



Fixed Point 

Load 

Load and Test 

Load Complement 

Load Positive 

Load Negative 

Add 

Add Logical 

Subtract 

Subtract Logical 

Compare 

Multiply 

Divide 



Logical 

Compare 
AND 
OR 
Exclusive OR 

Branching 

Branch on Condition 
Branch and Link 
Branch on Count 

RX Format 



Floating Point 

Load S/L 
Load and Test S/L 
Load Complement S/L 
Load Positive S/L 
Load Negative S/L 
Add Normalized S/L 
Add Unnormalized S/L 
Subtract Normalized S/L 
Subtract Unnormalized S/L 
Compare S/L 
Halve S/L 
Multiply S/L 
Divide S/L 

Status Switching 

Set Program Mask 2 

Supervisor Call 3 

Set Storage Key Z 

Insert Storage Key Z 



Op Code 


"i 


X, 


^2 


°2 



Op Code 


«i 


h 


=2 


°2 



Fixed Point 

Load Multiple 
Store Multiple 
Shift Left Single 
Shift Right Single 
Shift Left Double 
Shift Right Double 



SI Format 



2 

2 

E,2 

E,2 



logical 

Shift Left Single 
Shift Right Single 
Shift Left Double 
Shift Right Double 

Branching 

Branch on High 
Branch on Low-Eq 



Input/Output 

Start I/O 
Test I/O 
Halt I/O 
Test Channel 

Logical 

Move 

Compare 

AND 

OR 

Exclusive OR 

Test Under Mask 

SS Format 



Status Switching 

LoadPSW 
Set System Mask 
Write Direct 
Read Direct 
Diagnose 
Test and Set 



2 

2 

E,2 

E,2 



Op Code 


'2 


»1 


''^ 



Op Code 



^SL5J[3 



Fixed Point 




Floating Point 


Load H/F 




Load S/L 


Add H/F 




Add Normalized S/L 


Add Logical 




Add Unnormalized S/L 


Subtract H/F 




Subtract Normalized S/L 


Subtract Logical 




Subtract Unnormalized S/L 


Compare H/F 




Compare S/L 


Multiply H 




Multiply S/L 


Multiply F 


E 


Store S/L 


Divide F 


E 


Divide S/L 


Convert to Binary 






Convert to Decimal 






Store H/F 






Logical 




Branching 


Compare 




Branch on Condition 1 


Load Address 




Branch and Link 


Insert Character 




Branch on Count 


Store Character 




Execute 


AND 






OR 






Exclusive OR 







Decimi 


1/ 




Logical 




Pack 






Move 


5 


Unpack 




Move Numeric 


5 


Move With Offset 




Move Zone 


5 


Zero and Add 


T 


Compare 


5 


Add 




T 


AND 


5 


Subtract 


T 


OR 


5 


Compare 


T 


Exclusive OR 


5 


Multiply 


T 


Translate 


5 


Divide 




T 


Translate and Test 

Edit 

Edit and Mark 


5 
T,5 
T,5 


FORMAT NOTES 








E 


Ri must be even 








F 


FuUvi'ord 








H 


Halfword 








L 


Long 








S 


Short 








T 


Decimal feature 








Y 


Direct control feature 






Z 


Protection feature 






1 


Ri used as mask Mi 






2 


R2 or Rs ignored 








3 


Ri and R2 used as 


immediate information 




4 


I2 ignored 








5 


Li and L2 used 


as ei 


ght-bit L field 




All floating-point instructions 


are part of the floating-point fea- 


ture. 
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Control Word Formats 
Base and Index Registers 



Base Address or Index 



0-7 Ignored 

8-31 Base address or index 

Program Status Word 



Command Code Assignment 



NAMES 

Write 

Read 

Read Backward 

Control 

Sense 

Transfer in Channel 



FLAGS 

CD CC SLI PCI 

CD CC SLI SKIP PCI 
CD CC SLI SKIP PCI 
CD CC SLI PCI 

CD CC SLI SKIP PCI 



CD 
CC 
SLI 



Chain data 
Chain command 
Suppress length 
indication 



PCI 



CODE 
MMMM MMOI 
MMMM MM 10 
MMMM 1 100 
MMMM MM 11 
MMMM 1 00 
X X X X 1 000 



= Skip 

= Program- 
controlled 
interruption 



System Mask 


Key 


AMWP 


Interruption Code 


7S 1112 1516 


31 


U 

-J 




Program 
Mask 


Instruction Address 



Channel Address Word 



32 33 34 35 36 3940 


0-7 


System mask 





Channel 




mask 


1 


Channel 1 




mask 


2 


Channel 2 




mask 


3 


Channel 3 




mask 


4 


Channel 4 




mask 


5 


Channel 5 




mask 


6 


Channel 6 




mask 


7 


External mask 


8-11 


Protection key 


12 


ASCII-8mode (A) 



13 Machine check mask 
(M) 

14 Wait state (W) 

15 Problem state (P) 
16-31 Interruption code 
32-33 Instruction length 

code (ILC) 
34-35 Condition code (CC) 
36-39 Program mask 

36 Fixed-point overflow 
mask 

37 Decimal overflow 
mask 

38 Exponent underflow 
mask 

39 Significance mask 
40-63 Instruction address 



Channel Command Word 



Command 
Code 


Data Address 




Key 



Command Address 



0-3 Protection key 

4-7 Zero 

8-31 Command address 



Channel Status Word 



Key 


0000 


Command Address 


3 4 7 8 




31 


Status 


Count 



0-3 Protection key 


40 


Program-controlled 


4-7 Zero 




interruption 


8-31 Command address 


41 


Incorrect length 


32-47 Status 


42 


Program check 


32 Attention 


43 


Protection check 


33 Status modifier 


44 


Channel data check 


34 Control unit end 


45 


Channel control check 


35 Busy 


46 


Interface control 


36 Channel end 




check 


37 Device end 


47 


Chaining check 


38 Unit check 


48-63 Count 


39 Unit exception 







0-7 Command code 

8-31 Data address 

32-36 Command flags 

32 Chain data flag 

33 Chain command flag 

34 Suppress length 
indication flag 



35 Skip flag 

36 Program-controlled 
interruption flag 

37-39 Zero 
40-47 Ignored 
48-63 Count 
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Operation Codes 



RR FORMAT 



Branching and 
Status Switching 



Fixed -Point Full Word 
and Logical 



Floating-Point 
Long 



Floating-Point 
Short 



xxxx 

0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

nil 





OOOOxxxx 




0001 xxxx 




(X)10xxxx 


001 


xxxx 






LPR 


Load Positive 


LPDR 


Lood Positive 


LPER 


Load Positive 






LNR 


Load Negative 


LNDR 


Load Negative 


LNER 


Load Negative 






LTR 


Load and Test 


LTDR 


Load and Test 


LTER 


Load and Test 






LCR 


Lood Complement 


LCDR 


Load Complement 


LCER 


Load Complement 


SPM 


Set Program Mask 


NR 


AND 


HDR 


Halve 


HER 


Halve 


BALR 


Branch and Link 


CLR 


Compare Logical 










BCTR 


Branch on Count 


OR 


OR 










BCR 


Branch/Condition 


XR 


Exclusive OR 










SSK 


Set Key 


LR 


Lood 


LDR 


Load 


LER 


Load 


ISK 


Insert Key 


CR 


Compare 


CDR 


Compare 


CER 


Compare 


SVC 


Supervisor Call 


AR 


Add 


ADR 


Add N 


ALR 


AddN 






SR 


Subtract 


SDR 


Subtract N 


SER 


Subtract N 






MR 


Multiply 


MDR 


Multiply 


MER 


Multiply 






DR 


Divide 


DDR 


Divide 


DER 


Divide 






ALR 


Add Logical 


AWR 


Add U 


AUR 


AddU 






SLR 


Subtract Logical 


SWR 


Subtract U 


SUR 


Subtract U 



RX FORMAT 



Fixed-Point Halfword 
and Branching 



Fixed-Point Full Word 
and Logical 



FIcating-PoInt 
Long 



Floating-Point 
Short 



0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

1111 





OlOOxxxx 




OlOlxxxx 




OIlOxxxx 


01 11 xxxx 


STH 


Store 


ST 


Store 


STD 


Store 


STE Store 


LA 


Load Address 












SIC 


Store Character 












IC 


Insert Character 












EX 


Execute 


N 


AND 








BAL 


Branch and Link 


CL 


Compare Logical 








BCT 


Branch on Count 


O 


OR 








BC 


Branch/Condition 


X 


Exclusive OR 








LH 


Load 


L 


Load 


LD 


Load 


LE Load 


CM 


Compare 


C 


Compare 


CD 


Compare 


CE Compare 


AH 


Add 


A 


Add 


AD 


AddN 


AE Add N 


SH 


Subtract 


S 


Subtract 


SD 


Subtract N 


SE Subtract N 


MH 


Multiply 


M 


Multiply 


MD 


Multiply 


ME Multiply 






D 


Divide 


DD 


Divide 


DE Divide 


CVD 


Convert-Decimal 


AL 


Add Logical 


AW 


AddU 


AU Add U 


CVB 


Convert-Binary 


SL 


Subtract Logical 


SW 


Subtreict U 


SU Subtract U 



RS, SI FORMAT 

Branching Status 
Switching and Shifting 



0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

nil 



Fixed-Point Logical 
and Input/Output 





lOOOxxxx 




1001 xxxx 


lOIOxxxx 


lOllxxxx 


SSM 


Set System Mask 


STM 
TM 


Store Multiple 
Test Under Mask 






LPSW 


Load PSW 


MVI 


Move 








Diagnose 


TS 


Test and Set 






WRD 


Write Direct 


Nl 


AND 






RDD 


Read Direct 


CM 


Compare Logical 






BXH 


Branch/High 


Ol 


OR 






BXLE 


Branch/Low -Equal 


XI 


Exclusive OR 






SRL 


Shift Right SL 


LM 


Load Multiple 






SLL 


Shift Left SL 










SRA 


Shift Right S 










SLA 


Shift Left S 










SRDL 


Shift Right DL 


SIO 


Start I/O 






SLDL 


Shift Left DL 


TIO 


Test I/O 






SRDA 


Shift Right D 


HIO 


Halt I/O 






SLDA 


Shift Left D 


TCH 


Test Channel 







0000 
0001 
0010 
0011 
0100 
0101 
Olio 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

nil 

Note: 



llOOxxxx 



N = Normalized 
SL = Single Logical 



Logical 
1101 xxxx 



Decimal 
nilxxxx 





MVN 


Move Numeric 




MVO 


Move with Offset 




MVC 


Move 




PACK 


Pack 




MVZ 


Move Zone 




UNPK 


Unpack 




NC 


AND 










CLC 


Compare Logical 










OC 


OR 










xc 


Exclusive OR 




ZAP 
CP 
AP 
SP 


Zero and Add 
Compare 
Add 
Subtract 




TR 


Translate 




MP 


Multiply 




TRT 


Translate and Test 




DP 


Divide 




ED 


Edit 










EDMK 


Edit and Mark 









DL^ 

U ■■ 



Double Logical 
Unnormallzed 



S ' Single 
D - Double 
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Permanent Storage Assignment 



Logical Operations 



ADDRESS 

0000 0000 

0000 1000 

0001 0000 
0001 1000 
0010 0000 

0010 1000 

0011 0000 
0011 1000 
0100 0000 
0100 1000 

0100 1100 

0101 0000 
0101 0100 
0101 1000 
Olio 0000 
Olio 1000 
0111 0000 
0111 1000 
1000 0000 

* The size of the 
ticular model and 



LENGTH 



PURPOSE 





8 

16 

24 

32 

40 

48 

56 

64 

72 

76 

80 

84 

88 

96 

104 

112 

120 

128 



double word Initial program loading PSW 

double word Initial program loading CCWl 

double word Initial program loading CCW2 

double word External old PSW 

double word Supervisor call old PSW 

double word Program old PSW 

double word Machine-check old PSW 

double word Input/output old PSW 

double word Channel status word 

word Channel address word 

word Unused 

word Timer 

word Unused 

double word External new PSW 

double word Supervisor call new PSW 

double word Program new PSW 

double word Machine-check new PSW 

double word Input/output new PSW 

Diagnostic scan-out area* 
diagnostic scan-out area depends on the par- 
I/O channels. 



Condition Code Setting 



Fixed-Point Arithmetic 



Add H/F 
Add Logical 

Compare H/F 
Load and Test 
Load Complement 
Load Negative 
Load Positive 
Shift Left Double 
Shift Left Single 
Shift Right Double 
Shift Right Single 
Subtract H/F 
Subtract Logical 




zero 
zero, 
no carry 
equal 
zero 
zero 
zero 
zero 
zero 
zero 
zero 
zero 
zero 



Decimal Arithmetic 

Add Decimal zero 

Compare Decimal equal 

Subtract Decimal zero 

Zero and Add zero 



1 

< zero 
not zero, 
no carry 

low 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 

< zero 
not zero, 
no carry 



< zero 
low 

< zero 

< zero 



2 

> zero 
zero, 
carry 

high 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 

> zero 
zero, 
carry 



> zero 
high 

> zero 

> zero 



3 

overflow 

not zero, 

carry 

overflow 

overflow 
overflow 
overflow 



overflow 

not zero, 

carry 



overflow 

overflow 
overflow 



AND 


zero 


not zero 


__ 


Compare Logical 


equal 


low 


high 


Edit 


zero 


< zero 


> zero 


Edit and Mark 


zero 


< zero 


> zero 


Exclusive OR 


zero 


not zero 


— 


OR 


zero 


not zero 


— 


Test Under Mask 


zero 


mixed 


._ 


Translate and Test 


zero 


incomplete 


complel 


Status Switching 








Test and Set 


zero 


one 


.. 



Input/ Output Operations 

Halt I/O interruption 

pending 

Start I/O successful 



Test I/O 
Test Channel 



available 



available 



CSW 

stored 

CSW 

stored 

CSW 

stored 

inter- 
ruption 
pending 



burst op not oper- 
stopped ational 



busy 

busy 

burst 
mode 



not oper- 
ational 

not oper- 
ational 

not oper- 
ational 



CONDITION CODE SETTING NOTES 

available 

burst op 
stopped 

busy 

carry 

complete 

CSW stored 

equal 

F 

> zero 

H 

halted 

high 

incomplete 

L 

< zero 

low 

mixed 

not oper- 
ational 

not zero 

one 

overflow 

S 

zero 



Unit and channel available 
Burst operation stopped 

Unit or channel busy 

A carry out of the sign position occurred 

Last result byte nonzero 

Channel status word stored 

Operands compare equal 

FuUword 

Result is greater than zero 

Halfword 

Data transmission stopped. Unit in halt-reset mode 

First operand compares high 

Nonzero result byte; not last 

Long precision 

Result is less than zero 

First operand compares low 

Selected bits are both zero and one 

Unit or channel not operational 

Result is not all zero 

Selected bits are one 

Result overflows 

Short precision 

Result or selected bits are zero 
The condition code also may be changed by LOAD PSW, SET 
PROGRAM MASK, DIAGNOSE, and by an interruption. 



Floating-Point Arithmetic 



Interruption Action 



Add Normalized S/L 


zero 


< zero 


> zero 


overflow 


soxmcE 


Add Unnormalized S/L 


zero 


< zero 


> zero 


overflow 


IDENTIFICATION 


Compare S/L 
Load and Test S/L 


equal 
zero 


low 
< zero 


high 
> zero 


~ 


Input/Output 


Load Complement S/L 


zero 


< zero 


> zero 


~ 


Channel 


Load Negative S/L 


zero 


< zero 


— 


~ 


Channel 1 


Load Positive S/L 


zero 


— 


> zero 


— 


Channel 2 


Subtract 










Channel 3 


Normalized S/L 


zero 


< zero 


> zero 


overflow 


Channel 4 


Subtract Unnorm- 










Channel 5 


alized S/L 


zero 


< zero 


> zero 


overflow 


Channel 6 



INTERRUPTION CODE MASK ILC 

PSW srrs 16-31 bits set 



EXE- 
CUTION 



(old PSW 56, new PSW 120, Priority 4) 

X completed 

1 X completed 

2 X completed 

3 X completed 

4 X completed 

5 X completed 

6 X completed 



00000000 aaaaaaaa 

00000001 aaaaaaaa 

00000010 aaaaaaaa 

00000011 aaaaaaaa 

00000100 aaaaaaaa 

00000101 aaaaaaaa 
00000110 aaaaaaaa 
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Program (old PSW 40, new PSW 104, 

Operation 00000000 00000001 

Privileged 00000000 00000010 

operation 

Execute 00000000 00000011 

Protection 00000000 00000100 



Addressing 



Specification 
Data 

Fixed-point 
overflow 
Fixed-point divide 



Decimal overflow 
Decimal divide 
Exponent 

overflow 
Exponent 

underflow 
Significance 
Floating-point 

divide 



00000000 00000101 



00000000 00000110 
00000000 00000111 
00000000 00001000 

00000000 00001001 



36 



00000000 00001010 37 
00000000 00001011 
00000000 00001100 



priority 2) 

1,2,3 suppressed 

1.2 suppressed 

2 suppressed 
0,2,3 suppressed 
or 

terminated 
0,1,2,3 suppressed 
or 

tem^jnated 
1,2,3 suppt-essed 

2.3 terminated 
1,2 completed 

1,2 suppressed 
or 

completed 
completed 
suppressed 
terminated 



3 
3 
1,2 



00000000 00001101 38 1,2 completed 



00000000 00001110 39 
00000000 00001111 



1,2 completed 
1,2 suppressed 



Supervisor Call (old PSW 32, new PSW 96, priority 2) 



Inslvuction bits 00000000 rrrrrrrr 



completed 



External (old PSW 24, new PSW 88, priority 3) 

completed 
completed 
completed 



Timer 

Interrupt key 
External signal 2 
External signal 3 
External signal 4 
External signal 5 
External signal 6 
External signal 7 



00000000 Innnnnnn 
00000000 nlnnnnnn 
00000000 nnlnnnnn 
00000000 nnnlnnnn 
00000000 nnnnlnnn 
00000000 nnnnnlnn 
00000000 nnnnnnln 
00000000 nnnnnnnl 



completed 
completed 
completed 
completed 
completed 



Machine Check (old PSW 48, new PSW 112, priority 1) 

Machine 00000000 00000000 13 x terminated 

malfunction 



NOTES 

a 
n 



Device address bits 

Other external-interruption conditions 

Bits of Ri and Ra field of supervisor call 

Unpredictable 



Program Interruptions 

Exceptions resulting from improper specification or use 
of an instruction and data cause a program inter- 
ruption. 



Operation (OP) 

The operation code is not assigned or the assigned 

operation is not available on the particular cpu, 

The operation is suppressed. 

The instruction-length code is 1, 2, or 3. 



Privileged Operation (M) 

A privileged instruction is encountered in the problem 
state. 

The operation is suppressed. 

The instruction-length code is 1 or 2. 



Diagnose 
Halt I/O 

Insert Storage Key 
Load PSW 
Read Direct 
Set Storage Key 
Set System Mask 
Start I/O 
Test Channel 
Test I/O 
Write Direct 



MNEMONIC 

HIO 

ISK 

LPSW 

RDD 

SSK 

SSM 

SIO 

TCH 

TIO 

WRD 



SI 

SI 

RR 

SI 

SI 

RR 

SI 

SI 

SI 

SI 

SI 



ACTION 

Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Suppressed 



Execute (EX) 

The subject instruction of execute is another execute. 

The operation is suppressed. 

The instruction-length code is 2. 



Execute 



MNEMONIC 

EX 



FORMAT 

RX 



Suppressed 



Protection (P) 

The key of an instruction or operand location does not 
match the protection key in the PSW. 
The instruction length-code is 0, 2, or 3. 



Instruction Length Recording 







INSTRUC- 








PSW BITS 


TION 


INSTRUCTION 




CODE 


32-33 


BITS 0-1 


LENGTH 


FORMAT 





00 




Not available 




1 


01 


00 


One halfword 


RR 


2 


10 


01 


Two halfwords 


RX 


2 


10 


10 


Two halfwords 


RS or SI 


3 


11 


11 


Three halfwords 


SS 



Instructions Subject to Store Protection 

When the protection feature contains only the facility 
to monitor operations changing storage contents, the 
check is made for every use of the following instruc- 
tions. In addition, these instructions are subject to a 
protection exception when both store and fetch viola- 
tions are monitored. The operation is suppressed on a 
store violation, except in the case of store multiple, 
READ direct, TEST AND SET, and variablc-lcngth opera- 
tions, which are terminated. 
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Add Decimal 

AND 

AND 

Convert to Decimal 

Diagnose 

Divide Decimal 

Edit 

Edit and Mark 

Exclusive OR 

Exclusive OR 

Move 

Move 

Move Numerics 

Move with Offset 

Move Zones 

Multiply Decimal 

OR 

OR 

Pack 

Read Direct 

Store 

Store (long) 

Store (short) 

Store Character 

Store Halfword 

Store Multiple 

Test and Set 

Translate 

Unpack 

Zero and Add 



MNEMONIC 

AP 
NC 
NI 
CVD 

DP 

ED 

EDMK 

XC 

XI 

MVC 

MVI 

MVN 

MVO 

MVZ 

MP 

OC 

OI 

PACK 

RRD 

ST 

STD 

STE 

STC 

STH 

STM 

TS 

TR 

UNPK 

ZAP 



ss 
ss 

SI 

RX 

SI 

SS 

ss 
ss 
ss 

SI 

ss 

SI 

ss 
ss 
ss 
ss 
ss 

SI 

ss 

SI 

RX 

RX 

RX 

RX 

RX 

RS 

SI 

SS 

ss 
ss 



ACTION 

Terminated 

Terminated 

Suppressed 

Suppressed 

Unpredictable 

Terminated 

Terminated 

Terminated 

Terminated 

Suppressed 

Terminated 

Suppressed 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Suppressed 

Terminated 

Terminated 

Suppressed 

Suppressed 

Suppressed 

Suppressed 

Suppressed 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 



Instructions Subject to Fetch Protection 

When the protection feature contains the facility to 
monitor for both store and fetch violations, the follow- 
ing instructions can cause the exception only by a fetch 
violation. The operation is terminated, except in the 
case of EXECUTE, which is suppressed. 



NAME 

Add 

Add Halfword 
Add Logical 
Add Normalized 

(long) 
Add Normalized 

(short) 
Add Unnormalized 

(long) 
Add Unnormalized 

(short) 
AND 
Compare 
Compare 
Compare 
Compare 
Compare (long) 
Compare (short) 
Compare Decimal 
Compare Halfword 
Convert to Binary 
Divide 

Divide (long) 
Divide (short) 
Exclusive OR 
Execute 

Insert Character 
Load 

Load (long) 
Load (short) 



MNEMONIC 

A 

AH 

AL 

AD 

AE 

AW 

AU 

N 

C 

CL 

CLI 

CLC 

CD 

CE 

CP 

CH 

CVB 

D 

DD 

DE 

X 

EX 

IC 

L 

LD 

LE 



FORMAT 
RX 

RX 
RX 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

SI 

SS 

RX 

RX 

SS 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

RX 



ACTION 

Terminated 
Terminated 
Terminated 

Terminated 

Terminated 

Terminated 

Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Suppressed 
Terminated 
Terminated 
Terminated 
Terminated 



NAME 

Load Multiple 

Load PSW 

Multiply 

Multiply (long) 

Multiply (short) 

Multiply Halfword 

OR 

Set System Mask 

Subtract 

Subtract Halfword 

Subtract Logical 

Subtract Norm- 
alized (long) 

Subtract Norm- 
alized (short) 

Subtract Unnorm- 
alized (long) 

Subtract Unnorm- 
alized (short) 

Test Under Mask 

Translate And Test 

Write Direct 



MNEMONIC 

LM 

LPSW 

M 

MD 

ME 

MH 

O 

SSM 

S 

SH 

SL 

SD 

SE 

SW 

SU 
TM 
TRT 
WRD 



FORMAT 
RS 
SI 
RX 

RX 

RX 

RX 

RX 

SI 

RX 

RX 

RX 

RX 

RX 

RX 

RX 

SI 

SS 
SI 



Term 
Term 
Term 
Term 
Term 
Term 
Term 
Term 
Term 
Term 
Term 



nated 
nated 
nated 
nated 
nated 
nated 
nated 
nated 
nated 
nated 
nated 



Terminated 

Terminated 

Terminated 

Terminated 
Terminated 
Terminated 
Terminated 



Instructions Subject to Store and Fetch Protection 

When the protection feature contains the facility to 
monitor for both store and fetch violations, the follow- 
ing instructions can cause the exception either by a 
store or fetch violation. The operation is terminated, 
except in the case of diagnose, which is unpredictable. 



NAME 

Add Decimal 

AND 

Diagnose 

Divide Decimal 

Edit 

Edit And Mark 

Exclusive OR 

Move 

Move Numerics 

Move with Offset 

Move Zones 

Multiply Decimal 

OR 

Pack 

Subtract Decimal 

Test and Set 

Translate 

Unpack 

Zero and Add 



MNEMONIC 
AP 

NC 

DP 

ED 

EDMK 

XC 

MVC 

MVN 

MVO 

MVZ 

MP 

OC 

PACK 

SP 

TS 

TR 

UNPK 

ZAP 



FORMAT 
SS 

SS 
SI 

ss 
ss 
ss 
ss 
ss 
ss 
ss 
ss 
ss 
ss 
ss 
ss 

SI 

ss 
ss 
ss 



ACTION 

Terminated 

Terminated 

Unpredictable 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 

Terminated 



Addressing (A) 

An address specifies any part of data, instruction, or 
control words outside the available storage for the par- 
ticular installation. 

In most cases, the operation is terminated. Data in 
storage remain unchanged, except when designated by 
valid addresses. The operation is suppressed for con- 
vert TO DECIMAL, DIAGNOSE, EXECUTE, immediate in- 
structions (ni, XI, MVI, oi), and certain store-typo oper- 
ations ( ST, STC, STH, STD, and STE ) . 

The instruction-length code is normally 1, 2, or 3; 
however, it may be in the case of a data address. 
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Add 

Add Decimal 
Add Half word 
Add Logical 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Unnorm- 

alized (Long) 
Add Unnorm- 

alized (Short) 
AND 

AND 
AND 

Compare 
Compare Decimal 
Compare Halfword 
Compare Logical 
Compare Logical 
Compare Logical 
Compare (Long) 
Compare (Short) 
Convert to Binary 
Convert to Decimal 

Diagnose 
Divide 

Divide Decimal 
Divide (Long) 
Divide (Short) 

Edit 

Edit and Mark 

Exclusive OR 

Exclusive OR 

Exclusive OR 

Execute 

Insert Character 
Insert Storage Key 

Load 

Load Halfword 
Load (Long) 
Load Multiple 
Load PSW 
Load (Short) 

Move 

Move 

Move Numerics 

Move with Offset 

Move Zones 

Multiply 

Multiply Decimal 

Multiply Halfword 

Multiply ( Long ) 

Multiply (Short) 

OR 
OR 
OR 

Pack 

Read Direct 

Set Storage Key 

Set System Mask 

Store 

Store Character 

Store Halfword 

Store (Long) 

Store Multiple 



MNEMONIC 

A 
AP 
AH 
AL 

AD 

AE 

AW 

AU 

N 

NI 

NC 

C 

CP 

CH 

CL 

CLI 

CLC 

CD 

CE 

CVB 

CVD 

D 
DP 
DD 
DE 

ED 

EDMK 

X 

XI 

XC 

EX 

IC 
ISK 

L 

LH 

LD 

LM 

LPSW 

LE 

MVI 
MVC 

MVN 

MVO 

MVZ 

M 

MP 

MH 

MD 

ME 

O 

OI 

OC 

PACK 

RDD 

SSK 

SSM 

ST 

STG 

STH 

STD 

STM 



FORMAT 

RX 
SS 
RX 
RX 

RX 

RX 

RX 

RX 
RX 

SI 

SS 

RX 

SS 

RX 

RX 

SI 

SS 

RX 

RX 

RX 

RX 

SI 

RX 

SS 

RX 

RX 

SS 

SS 

RX 

SI 

SS 

RX 

RX 
RR 

RX 

RX 

RX 

RS 

SI 

RX 

SI 

SS 

SS 

SS 

SS 

RX 

SS 

RX 

RX 

RX 

RX 
SI 

SS 

SS 

SI 

RR 

SI 

RX 

RX 

RX 

RX 

RS 



ACTION 

Terminated 
Terminated 
Terminated 
Terminated 

Terminated 

Terminated 

Terminated 

Terminated 
Terminated 

Suppressed 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Suppressed 

Suppressed 
Terminated 
Terminatcid 
Terminated 
Terminated 

Terminated 
Terminated 
Terminated 
Suppressed 
Terminated 
Suppressed 

Terminated 
Terminated 

Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 

Suppressed 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 

Terminated 
Suppressed 
Terminated 

Terminated 

Terminated 

Suppressed 
Terminated 
Suppressed 
Suppressed 
Suppressed 
Suppressed 
Terminated 



NAME 


MNEMONIC 


FORMAT 


ACTION 


Store (Short) 


STE 


RX 


Suppressed 


Subtract 


S 


RX 


Terminated 


Subtract Decimal 


SP 


SS 


Terminated 


Subtract Halfword 


SH 


RX 


Terminated 


Subtract Logical 


SL 


RX 


Terminated 


Subtract Norm- 








alized (Long) 


SD 


RX 


Tenninated 


Subtract Norm- 








alized (Short) 


SE 


RX 


Tenninated 


Subtract Un- 








normalized 








(Long) 


SW 


RX 


Tenninated 


Subtract Un- 








normalized 








(Short) 


SU 


RX 


Terminated 


Test Under Mask 


TM 


SI 


Terminated 


Test and Set 


TS 


SI 


Terminated 


Translate 


TR 


SS 


Terminated 


Translate and 








Test 


TRT 


SS 


Terrainated 


Unpack 


UNPK 


SS 


Terminated 


Write Direct 


WRD 


SI 


Terminated 


Zero and Add 


ZAP 


SS 


Terminated 



The addressing interruption can occur in normal sequential 
operation following branching, load psw, interruption, or man- 
ual operation. Instruction execution is suppressed. 



Specification (S) 

1. A data, instruction, or control-word address does 
not specify an integral boundary for the unit of in- 
formation. 

2. The Ri field of an instruction specifies an odd 
register address for a pair of general registers that 
contain a 64-bit operand. 

3. A floating-point register address other than 0, 2, 
4, or 6 is specified. 

4. The multiplier or divisor in decimal arithmetic 
exceeds 15 digits and sign. 

5. The first operand field is shorter than or equal to 
the second operand field in decimal multiplication or 
division. 

6. The block address specified in set storage key 
or INSERT STORAGE KEY has the four low-order bits not 
all zero. 

7. A PSW with a nonzero protection key is en(30un- 
tered when the protection feature is not installed. 

In all of these cases the operation is suppressed. 
The instruction-length code is 1, 2, or 3. 



Add 

Add Halfword 
Add Logical 
Add Normalized 

(Long) 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Normalized 

(Short) 



MNEMONIC 
A 

AH 
AL 



ADR 
AD 



AER 



AE 



RX 
RX 
RX 

RR 

RX 

RR 

RX 



ACTION NOTE 

Suppressed 4 

Suppressed 2 

Suppressed 4 

Suppressed 3 

Suppressed 3,8 

Suppressed 3 

Suppressed 3,4 
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NAME MNEMONIC 


FORMAT 


ACTION 


NOTE 


NAME MNEMONIC 


FORMAT 


ACTION 


NOTE 


Add Unnorm- 










Multiply 










alized (Long) 


AWR 


RR 


Suppressed 


3 


Decimal 


MP 


SS 


Suppressed 


5 


Add Unnorm- 










Multiply 










alized (Long) 


AW 


RX 


Suppressed 


3,8 


Halfword 


MH 


RX 


Suppressed 


2 


Add Unnorm- 










Multiply ( Long ) 


MDR 


RR 


Suppressed 


3 


alized (Short) 


AUR 


RR 


Suppressed 


3 


Multiply (Long) 


MD 


RX 


Suppressed 


3,8 


Add Unnorm- 










Multiply (Short) 


MER 


RR 


Suppressed 


3 


ahzed (Short) 


AU 


RX 


Suppressed 


3,4 


Multiply (Short) 


ME 


RX 


Suppressed 


3,4 


AND 


N 


RX 


Suppressed 


4 












Compare 


C 


RX 


Suppressed 


4 


OR 


O 


RX 


Suppressed 


4 


Compare 










Set Storage 










Halfword 


CH 


RX 


Suppressed 


2 


Key 


SSK 


RR 


Suppressed 




Compare 










Shift Left 










Logical 


CL 


RX 


Suppressed 


4 


Double 


SLDA 


RS 


Suppressed 




Compare 










Shift Left 










(Long) 


CDR 


RR 


Suppressed 


3 


Double 










Compare 










Logical 


SLDL 


RS 


Suppressed 




(Long) 


CD 


RX 


Suppressed 


3,8 


Shift Right 










Compare 










Double 


SRDA 


RS 


Suppressed 




(Short) 


CER 


RR 


Suppressed 


3 


Shift Right 










Compare 










Double 










(Short) 


CE 


RX 


Suppressed 


3,4 


Logical 


SRDL 


RS 


Suppressed 




Convert to 










Store 


ST 


RX 


Suppressed 


4 


Binary 


CVB 


RX 


Suppressed 


8 


Store Halfword 


STH 


RX 


Suppressed 


2 


Convert to 










Store (Long) 


STD 


RX 


Suppressed 


3,8 


Decimal 


CVD 


RX 


Suppressed 


8 


Store Multiple 


STM 


RS 


Suppressed 


4 


Diagnose 




SI 


Suppressed 




Store (Short) 


STE 


RX 


Suppressed 


3,4 


Divide 


DR 


RR 


Suppressed 


I 


Subtract 


S 


RX 


Suppressed 


4 


Divide 


D 


RX 


Suppressed 


1,4 


Subtract 










Divide Decimal 


DP 


ss 


Suppressed 


5 


Halfword 


SH 


RX 


Suppressed 


2 


Divide (Long) 


DDR 


RR 


Suppressed 


3 


Subtract 










Divide (Long) 


DD 


RX 


Suppressed 


3,8 


Logical 


SL 


RX 


Suppressed 


4 


Divide (Short) 


DER 


RR 


Suppressed 


3 


Subtract Norm- 










Divide (Short) 


DE 


RX 


Suppressed 


3,4 


alized (Long) 
Subtract Norm- 


SDR 


RR 


Suppressed 


3 


Exclusive OR 
Execute 


X 

EX 


RX 
RX 


Suppressed 
Suppressed 


4 

2 


alized (Long) 
Subtract Norm- 


SD 


RX 


Suppressed 


3,8 


Halve (Long) 


HDR 


RR 


Suppressed 


3 


alized (Short) 


SER 


RR 


Suppressed 


3 


Halve (Short) 


HER 


RR 


Suppressed 


3 


Subtract Norm- 










Insert Storage 
Key 


ISK 


RR 


Suppressed 


7 


alized ( Short ) 
Subtract Un- 
normalized 


SE 


RX 


Suppressed 


3,4 


Load 


L 


RX 


Suppressed 


4 


(Long) 


SWR 


RR 


Suppressed 


3 


Load and Test 










Subtract Un- 










(Long) 


LTDR 


RR 


Suppressed 


3 


normalized 










Load and Test 










(Long) 


SW 


RX 


Suppressed 


3,8 


(Short) 


LTER 


RR 


Suppressed 


3 


Subtract Un- 










Load Comple- 










normalized 










ment (Long) 


LCDR 


RR 


Suppressed 


3 


(Short) 


SUR 


RR 


Suppressed 


3 


Load Comple- 










Subtract Un- 










ment (Short) 


LCER 


RR 


Suppressed 


3 


normalized 










Load Halfword 


LH 


RX 


Suppressed 


2 


(Short) 


SU 


RX 


Suppressed 


3,4 


Load ( Long ) 


LDR 


RR 


Suppressed 


3 












Load (Long) 


LD 


RX 


Suppressed 


3,8 












Load 










The specification 


interruption 


can occur 


in normal se 


quential 


Multiple 


LM 


RS 


Suppressed 


4 


operation following branching, 


LOAD PSW 


interruption. 


or man- 


Load Negative 










ual operation ( Note 1 ) . 








(Long) 


LNDR 


RR 


Suppressed 


3 












Load Negative 




















(Short) 


LNER 


RR 


Suppressed 


3 












Load Positive 










SPECIFICATION INTERRUPTION NOTES 






(Long) 
Load Positive 

(Short) 
Load PSW 
Load (Short) 
Load (Short) 


LPDR 

LPER 
LPSW 
LER 
LE 


RR 

RR 
SI 
RR 
RX 


Suppressed 

Suppressed 
Suppressed 
Suppressed 
Suppressed 


3 

3 

8 

3 

3,4 


1 Even register specification 

2 Two-byte unit of information specification 

3 Floating-point register specification 

4 Four-byte unit of information specification 

5 Decimal multiplier or divisor size specification 

6 Zero protection key specification 




Multiply 


MR 


RR 


Suppressed 


1 


7 Block address specification 






Multiply 


M 


RX 


Suppressed 


1,4 


8 Eight-byte unit of information specification 
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Data (D) 

1. The sign or digit codes of operands in decimal 
arithmetic, or editing operations, or convert to 
BINARY, are incorrect. 

2. Fields in decimal arithmetic overlap incorrectly, 

3. The decimal multiplicand has too many high- 
order significant digits. 

The operation is terminated in all three cases. 
The instruction-length code is 2 or 3. 



MNEMONIC FORMAT 



Add Decimal 
Compare 

Decimal 
Convert to 

Binary 
Divide Decimal 
Edit 

Edit and Mark 
Multiply 

Decimal 
Subtract 

Decimal 
Zero and Add 



AP 

CP 

CVB 
DP 
ED 
EDMK 

MP 

SP 
ZAP 



ss 
ss 

RX 

SS 
SS 

ss 

SS 

ss 
ss 



ACTION 

Terminated 

Terminated 

Terminated 
Terminated 
Terminated 
Terminated 



NOTE 

1,2 

1,2 

1 

1,2 

1 

1 



Terminated 1,2,3 



Terminated 
Terminated 



1,2 
1,2 



DATA INTEBRUPTION NOTES 



1 All instructions listed may have incorrect sign or digit 

codes. 

2 Overlapping fields 

3 Multiplicand length 

Fixed-Point Overflow (IF) 

A high-order carry occurs or high-order significant bits 
are lost in fixed-point addition, subtraction, shifting, 
or sign-control operations. 

The operation is completed by ignoring the infor- 
mation placed outside the register. The interruption 
may be masked by psw bit 36. 

The instruction-length code is 1 or 2. 



Add 

Add 

Add Halfword 

Load Complement 

Load Positive 

Shift Left Double 

Shift Left Single 

Subtract 

Subtract 

Subtract Halfword 



MNEMONIC 

AR 

A 

AH 

LCR 

LPR 

SLDA 

SLA 

SR 

S 

SH 



FORMAT 

RR 
RX 
RX 
RR 
RR 
RS 
RS 
RR 
RX 
RX 



ACTION 

Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 



Fixed-Point Divide (IK) 

1. The quotient exceeds the register size in fixed- 
point division, including division by zero. 

2. The result of convert to binary exceeds 31 bits. 
Division is suppressed. Conversion is completed by 

ignoring the information placed outside the register. 
The instruction-length code is 1 or 2. 



Convert to Binary 

Divide 

Divide 



MNEMONIC 

CVB 

DR 

D 



FORMAT 
RX 
RR 

RX 



ACTION 

Completed 
Suppressed 
Suppressed 



Decimal Overflow (DF) 

The destination field is too small to contain the result 

field in decimal operations. 

The operation is completed by ignoring the over- 
flow information. The interruption may be masked by 
PSW bit 37. 

The interruption-length code is 3. 



NAME 

Add Decimal 
Subtract Decimal 
Zero and Add 



MNEMONIC 

AP 
SP 
ZAP 



SS 

ss 
ss 



ACTION 

Completed 
Completed 
Completed 



Decimal Divide (DK) 

The quotient exceeds the specified data field. 

The operation is suppressed. 

The instruction-length code is 3. 



NAME 

Divide Decimal 



MNEMONIC 

DP 



FORMAT 

ss 



ACTION 

Suppressed 



Exponent Overflow (E) 

TTie result characteristic exceeds 127 in floating-point 
addition, subtraction, multiplication, or division. 

The operation is terminated. 

The instruction-length code is 1 or 2. 



NAME 

Add Normalized 

(Long) 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Normalized 

(Short) 
Add Unnorm- 

alized (Long) 
Add Unnorm- 

alized (Long) 
Add Unnorm- 

alized (Short) 
Add Unnorm- 

alized (Short) 
Divide (Long) 
Divide (Long) 
Divide (Short) 
Divide (Short) 
Multiply (Long) 
Multiply (Long) 
Multiply (Short) 
Multiply (Short) 
Subtract Norm- 
alized (Long) 
Subtract Norm- 
alized (Long) 
Subtract Norm- 
alized (Short) 
Subtract Norm- 
alized (Short) 
Subtract Unnorm- 

alized ( Long ) 
Subtract Unnorm- 

alized (Long) 
Subtract Unnorm- 

alized (Short) 

Subtract Unnorm- 

alized (Short) 



MNEMONIC 

ADR 

AD 

AER 

AE 

AWR 

AW 

AUR 

AU 

DDR 

DD 

DER 

DE 

MDR 

MD 

MER 

ME 

SDR 

SD 

SER 

SE 

SWR 

SW 

SUR 

SU 



FORMAT 

RR 

RX 

RR 

RX 

RR 

RX 

RR 

RX 
RR 
RX 
RR 
RX 
RR 
RX 
RR 
RX 

RR 
RX 
RR 
RX 
RR 
RX 
RR 
RX 



ACTXON 

Terminated 

Terminated 

Terminated 

Terminiated 

Terminated 

Terminated 

Terminated 

Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 

Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
Terminated 
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Exponent Underflow (U) 

The result characteristic is less than zero in floating- 
point addition, subtraction, multiplication, or division. 

Tie operation is completed by making the result of 
the operation a true zero. The interruption may be 
masked by psw bit 38. 

The instruction-length code is 1 or 2. 



NAME 

Add Normalized 

(Long) 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Normalized 

(Short) 
Divide (Long) 
Divide (Long) 
Divide (Short) 
Divide (Short) 
Multiply ( Long ) 
Multiply (Long) 
Multiply ( Short ) 
Multiply (Short) 
Subtract Norm- 
alized ( Long ) 
Subtract Norm- 
alized (Long) 
Subtract Norm- 
alized (Short) 
Subtract Norm- 
alized (Short) 



MNEMONIC 

ADR 

AD 

AER 

AE 

DDR 

DD 

DER 

DE 

MDR 

MD 

MER 

ME 

SDR 
SD 

SER 
SE 



FORMAT 
RR 

RX 

RR 

RX 
RR 
RX 
RR 
RX 
RR 
RX 
RR 
RX 

RR 
RX 
RR 
RX 



ACTION 

Completed 

Completed 

Completed 

Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 

Completed 
Completed 
Completed 
Completed 



Significance (LS) 

The result of a floating-point addition or subtraction 

has an all-zero fraction. 

The operation is completed. The interruption may 
be masked by psw bit 39. The manner in which the 
operation is completed is determined by the mask bit. 

The instruction-length code is 1 or 2. 

MNEMONIC FORMAT ACTION 

ADR RR Completed 

AD RX Completed 

AER RR Completed 

AE RX Completed 

AWR RR Completed 



NAME 

Add Normalized 

(Long) 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Normalized 

(Short) 
Add Unnorm- 

alized (Long) 



NAME 

Add Unnorm- 
alized (Long) 

Add Unnorm- 
alized (Short) 

Add Unnorm- 
alized (Short) 

Subtract Norm- 
alized (Long) 

Subtract Norm- 
alized (Long) 

Subtract Norm- 
alized (Short) 

Subtract Norm- 
alized (Short) 

Subtract Unnorm- 
alized (Long) 

Subtract Unnorm- 
alized (Long) 

Subtract Unnorm- 
alized (Short) 

Subtract Unnorm- 
alized (Short) 



MNEMONIC 



AW 



AUR 

AU 

SDR 

SD 

SER 

SE 

SWR 

SW 

SUR 

SU 



FORMAT 

RX 
RR 
RX 
RR 
RX 
RR 
RX 
RR 
RX 
RR 
RX 



ACTION 

Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 
Completed 



Floating-Point Divide (FK) 

Division by a floating-point number with zero fraction 

is attempted. 

The operation is suppressed. 

The instruction-length code is 1 or 2. 



Divide (Long) 
Divide (Long) 
Divide (Short) 
Divide (Short) 



MNEMONIC 

DDR 
DD 
DER 
DE 



FORMAT 
RR 

RX 
RR 
RX 



Suppressed 
Suppressed 
Suppressed 
Suppressed 



Functions that May Differ Among Models 

Instruction Execution 

In the editing operations, overlapping fields give un- 
predictable results. 

Equipment connected to the hold-in line of read 
DIRECT should be so constructed that the hold signal 
will be removed when read direct is performed. Ex- 
cessive duration of this instruction may result in in- 
complete updating of the timer. 

The purpose of the I2 field and the operand address 
in the si format of diagnose may be further defined 
for a particular cpu and its appropriate diagnostic 
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procedures. Similarly the number of low-order address 
bits that must be zero is further specified for a par- 
ticular CPU. When the address does not have the re- 
quired number of low-order zeros, a specification ex- 
ception is recognized and causes a program interrup- 
tion. 

Whether diagnose is subject to protection action 
depends on the model. 

The diagnose operation is completed either by tak- 
ing the next sequential instruction or by obtaining a 
new psvt' from location 112. The diagnostic procedure 
may affect the problem, supervisor, and interruptable 
states of the cpu, and the contents of storage registers 
and timer, as well as the progress of i/o operations. 



Instruction Termination 

Only one program interruption occurs for a given iil- 
struction. The old psw always identifies a valid cause. 
This does not preclude simultaneous occurrence of 
any other causes. Which of several causes is identified 
may vary from one occasion to the next and from one 
model to another. 

When instruction execution is terminated by an in- 
terruption, all, part, or none of the result may be 
stored. The result data, therefore, are unpredictable. 
The setting of the condition code, if called for, may 
also be unpredictable. In general, the results of the 
operation should not be used for further computation. 

Cases of instruction termination for a program in- 
terruption are: 

Protection: The key of the addressed storage loca- 
tion does not match the protection key in the Psw. A 
store violation causes the operation to be terminated 
in the case of store multiple, read direct, test and 
SET, and variable-length operations. Protected stor- 
age remains unchanged. The timing signals of read 
direct may have been made available. The operation 
is terminated on a fetch violation, except for execute, 
which is suppressed. 

Addressing: An address specifies any part of data, 
instruction, or control word outside the available stor- 
age for the particular installation. In most cases the 
operation is terminated. Data in storage remain un- 
changed, except when designated by valid addresses. 

When part of an operand in clc is specified in an 
unavailable location, the comparison may end at an 
inequality, or the operation may be terminated by the 
addressing exception, even though inequality could 
have been established from the available operand 
parts. 



Data: The sign or digit codes of operands in deci- 
mal arithmetic, convert to binary, or editing opera- 
tions are incorrect, or fields in decimal arithmetic over- 
lap incorrectly, or the decimal multiplicand ha.^ too 
many high-order significant digits. The operation is 
terminated in all three cases. The condition codes set- 
ting, if called for, is unpredictable for protection, ad- 
dressing, and data exceptions. 

Exponent Overflow: The result exponent of an add, 
SUBTRACT, multiply, or DIVIDE ovcrflows and the re- 
sult fraction is not zero. The operation is terminated. 
The condition code is set to 3 for add and subtract, 
and remains unchanged for multiply and divide. 

Machine-Check Interruption 

For a machine-check interruption, the old psw is 
stored at location 48 with a zero interruption c;ode. 
The state of the cpu is scanned out into the storage 
area starting with location 128 and extending through 
as many words as are required by the given cpu. The 
new PSW is fetched from location 112. Proper execu- 
tion of these steps depends on the nature of the ma- 
chine check. A change in the machine-check mask bit 
due to the loading of a new psw results in a change 
in the treatment of machine checks. Depending upon 
the nature of a machine check, the old treatment may 
still be in force for several cycles. Machine checks that 
occur in operations executed by i/o channels may 
either cause a machine-check interruption or are re- 
corded in the csw for that operation. 



Instruction-Length Code 

The instruction-length code is predictable only for 
program and supervisor-call interruptions. For i/o and 
external interruptions, the interruption is not caused 
by the last interpreted instruction, and the code is not 
predictable for these classes of interruptions. For ma- 
chine-check interruptions, the setting of the code is a 
function of the malfunction and therefore unpredict- 
able. 

For the supervisor-call interruption the instruction- 
length code is 1, indicating the half word length of 
supervisor CALL; for the program interruptions, the 
codes 1, 2, and 3 indicate the instruction lengtli in 
halfwords. The code is reserved for progiam inter- 
ruptions where the length of the instruction is not 
available because of certain overlap conditions in in- 
struction fetching. In those cases, the instruction ad- 
dress in the old psw does not represent th(i next in- 
struction address. The instruction-length code can 
occur only for a program interruption caused by a 
protected or unavailable data address. 
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Timer 

Updating of the timer may be omitted when i/o data 
transmission approaches the limit of storage capabihty 
and when a channel sharing cpu equipment and op- 
erating in burst mode causes cpu activity to be locked 
out. 

When a high-resolution timer is installed, the follow- 
ing rules apply: 

1. Use of the contents of location 83 as a source of 
an instruction yields unpredictable results. 

2. The storing of data by the channel at location 83 
has an unpredictable effect on the eight low-order bits 
of the timer value, while fetching of data by the chan- 
nel from word location 83 yields unpredictable results. 

3. In a system having shared storage, storing in the 
low-order byte of another cpu's timer has an unpre- 
dictable effect on the eight low-order bits of the timer 
value, while a fetch-type operation to the timer loca- 
tion of another cpu causes the content of the low-order 
byte to be unpredictable. 

System Control Panel 

The system-reset function may correct the parity of 
general and floating-point registers, as well as the 
parity of the psw. 

Pressing the start key after a system reset without 
first introducing a new instruction address yields 
unpredictable results. 

The number of data switches is sufficient to allow 
storing of a full physical storage word. Correct parity 
generation is provided. In some models, either correct 
or incorrect parity is generated under switch control. 

The data in the storage, general register or floating- 
point register location, or the instruction-address part 
of the PSW as specified by the address switches and 
the storage-select switch can be displayed by the dis- 
play key. When the location designated by the address 
switches and storage-select switch is not available, the 
displayed information is unpredictable. In some mod- 
els, the instruction address is permanently displayed 
and hence is not explicitly selected. 

When the address-comparison switches are set to 
the stop position, the address in the address switches 
is compared against the value of the instruction ad- 
dress on some models, and against all addresses on 
others. Comparison includes only that part of the in- 
struction address corresponding to the physical word 
size of storage. 

Comparison of the entire halfword instruction ad- 
dress is provided in some models, as is the ability to 
compare data addresses. 

The test light may be on when one or more diag- 
nostic functions under control of diagnose are acti- 
vated, or when certain abnormal circuit breaker or 
thermal conditions occur. 



Normal Channel Operation 

Channel capacity depends on the way i/o operations 
are programmed and the activity in the rest of the 
system. In view of this, an evaluation of the ability 
of a specific i/o configuration to function concurrent- 
ly must be based on the application. Two systems em- 
ploying identical complements of i/o devices may be 
able to execute certain programs in common, but it 
is possible that other programs requiring, for example, 
data chaining may not run on one of the systems. 

The time when the interruption due to the pci flag 
occurs depends on the model and the current activity. 
The channel may cause the interruption an unpredict- 
able time after control of the operation is taken over 
by the ccw containing the pci flag. 

The content of the count field in a csw associated 
with an interruption due to the pci flag is unpredict- 
able. The content of the count field depends on the 
model and its current activity. 

When the interruption condition due to the pci flag 
has been delayed until the operation at the subchannel 
has been terminated, two interruptions from the sub- 
channel still may take place, with the first interruption 
indicating and clearing the pci condition alone, and 
the second providing the csw associated with the end- 
ing status. Whether one or two interruptions occur de- 
pends on the model, and on whether the pci condition 
has been assigned the highest priority for interruption 
at the time of termination. 

When the channel has established which device on 
the channel will cause the next i/o interruption, the 
identity of the device is preserved in the channel. Ex- 
cept for conditions associated with termination of an 
operation at the subchannel, the current assignment 
of priority for interruptions among devices may or 
may not be canceled when start i/o or test i/o is 
issued to the channel, depending upon the model. 

The assignment of priority among requests for in- 
terruption from channels is based on the type of chan- 
nel. The priorities of selector channels are in the order 
of their addresses, with channel 1 having the highest 
priority. The interruption priority of the multiplexor 
channel is not fixed, and depends on the model and 
the current activity in the channel. 

Channel Programming Errors 

A data address referring to a location not provided in 
the model normally causes program check when the 
device offers a byte of data to be placed at the non- 
existent location or requests a byte from that location. 
Models in which the channel does not have the ca- 
pacity to address 16,777,216 bytes of storage cause 
program check whenever the address is found to ex- 
ceed the addressing capacity of the channel. 
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In the following cases, action depends on the ad- 
dressing capacity of the model. 

1. When the data address in the ccw designated 
by the caw exceeds the addressing capacity of the 
model, the i/o operation is not initiated and the csw 
is stored during the execution of start i/o. Normally 
an invalid data address does not preclude the initi- 
ation of the operation. 

2. When the data address in a ccw fetched during 
command chaining exceeds the addressing capacity of 
the model, the i/o operation is not initiated. 

3. When a ccw fetched on data chaining contains 
an address exceeding the addressing capacity of the 
model and the device signals channel end immediate- 
ly upon transferring the last byte designated by the 
preceding ccw, program check is indicated to the pro- 
gram. Normally, program check is not indicated un- 
less the device attempts to transfer one more byte of 
data. 

4. Data addresses are not checked for validity dur- 
ing skipping, except that the initial data address in 
the ccw cannot exceed the addressing capacity of the 
model. 

When the channel detects chaining check, program 
check, or protection check, the content of the count 
field in the associated csw is unpredictable. 

When the channel detects a programming error in 
the CAW or in the first ccw, the pci bit may unpre- 
dictably appear in a csw stored by start i/o without 
the PCI flag being on in the first ccw associated with 
the START i/o. 

When a programming error occurs in the informa- 
tion placed in the caw or ccw and the addressed 
channel or subchannel is working, either condition 
code 1 or 2 may be set, depending on the model. 
Similarly, either code 1 or 3 may be set when a pro- 
gramming error occurs and a part of the addressed 
i/o system is not operational. 

When a programming error occurs and the ad- 
dressed device contains an interruption condition, 
with the channel and subchannel in the available 
state, START i/o may or may not clear the interruption 
condition, depending on the type of error and the 
model. If the instruction has caused the device to be 
interrogated, as indicated by the presence of the busy 
bit in the csw, the interruption condition has been 
cleared, and the csw contains program check, as well 
as the status from the device. 



When the channel detects several error conditions, 
all conditions may be indicated or only one may ap- 
pear in the csw, depending on the condition and the 
model. 

Channel Equipment Errors 

Parity errors detected by the channel on data sent to 
or received from the i/o device on some models cause 
the current operation to be terminated. When the 
channel and the cpu share common equipment, parity 
errors on data may cause malfunction reset to be per- 
formed. The recovery procedure in the channel and 
subsequent state of the subchannel upon a malfimc- 
tion reset depend on the model. 

Detection of channel control check or interface con- 
trol check causes the current operation, if any, to be 
immediately terminated and causes the channel to |)er- 
form the malfunction-reset function. The recovery pro- 
cedure in the channel and the subsequent state of the 
subchannel upon a malfunction reset depend on the 
model. 

The contents of the csw, as well as the address in 
the psw identifying the i/o device, are unpredictable 
upon the detection of a channel-control-check con- 
dition. 

Some channels can tolerate an absence of data trans- 
fer during a burst mode operation, such as occurs 
when reading a long gap on tape, for not more than 
approximately one-half minute. Equipment malfunc- 
tion may be indicated when an absence of data trans- 
fer exceeds this time. 

Execution of malfunction reset in the channel de- 
pends on the type of error and model. It may cause 
all operations in the channel to be terminated and all 
operational subchannels to be reset to the available 
state. The channel may send the malfunction-reset 
signal to the device connected to the channel at the 
time the malfunctioning is detected, or a channel shar- 
ing common equipment with the cpu may send the 
system-reset signal to all devices attached to the chan- 
nel. 

The method of processing a request for interruption 
due to equipment malfunctioning, as indicated by the 
presence of the channel-control-check and interface- 
control-check conditions, depends on the model. In 
channels sharing common equipment with the cpu, 
malfunctioning detected by the channel may be indi- 
cated by the machine-check interruption. 
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Alphabetic List of Instructions 

The listings in the type and excefhons columns mean: 

A Addressing exception 

C Condition code is set 

D Data exception 

DF Decimal-overflow exception 

DK Decimal-divide exception 

E Exponent-overflow exception 

EX Execute exception 

F Floating-point feature 

FK Floating-point divide exception 

IF Fixed-point overflow exception 

IK Fixed-point divide exception 

L New condition code loaded 

LS Significance exception 

M Privileged-operation exception 

P Protection exception 

S Specification exception 

T Decimal feature 

U Exponent-underflow exception 

Y Direct control feature 

Z Protection feature 



EXCEPTIONS 



MNE- 
MONIC 

AR 

A 

AP 

AH 

ALR 

AL 

ADR 

AD 

AER 



Add 

Add 

Add Decimal 

Add Halfword 

Add Logical 

Add Logical 

Add Normalized 

(Long) 
Add Normalized 

(Long) 
Add Normalized 

(Short) 
Add Normalized 

(Short) AE 

Add Unnorm- 

alized(Long) AWR 
Add Unnorm- 

alized (Long) AW 

Add Unnorm- 

alized (Short) AUR 
Add Unnorm- 

alized (Short) AU 

AND NR 

AND N 

AND NI 

AND NC 

Branch and Link BALR 
Branch and Link BAL 
Branch on 

Condition BCR 

Branch on 

Condition BC 

Branch on Count BCTR 
Branch on Count BCT 
Branch on Index 

High 
Branch on Index 

Low or Equal BXLE 

Compare CR 

Compare C 

Compare Decimal CP 
Compare Halfword CH 



RR C 
RX C 
SS T,C 
RX C 
RR C 
RX C 

RRF,C 

RXF.C 

RRF,C 

RXF.C 

RRF,C 

RXF,C 

RRF,C 

RXF,C 
RR C 
RX C 
SI C 

SS x,c 

RR 
RX 

RR 

RX 
RR 
RX 



BXH RS 



RS 
RR 
RX 



EXCEPTIONS 


CODE PG. 


IF 


lA 28 


P,A,S, IF 


5A 28 


P,A, D, DF 


FA 37 


P,A,S, IF 


4A 28 




IE 28 


P,A,S 


5E 28 



S,U,E,LS 
P,A,S,U,E,LS 

S,U,E,LS 
P,A,S,U,E,LS 

S, E,LS 
P,A,S, E,LS 

S, E,LS 

P,A,S, E,LS 

P,A,S 

P,A 

P,A 



C 
C 

SS T,C 
RX C 



P,A,S 
P,A, D 
P,A,S 



2A 45 

6A 45 

3A 45 

7A 45 

2E 46 

6E 46 

3E 46 

7E 46 

14 55 

54 55 

94 55 

D4 55 

05 66 

45 66 

07 65 

47 65 

06 66 

46 66 

86 66 

87 66 
19 30 
59 30 
F9 38 
49 30 



PAS 
P,A 
P,A 
P,A,S, 



NAME MONIC TYPE 

Compare Logical CLR RR C 

Compare Logical CL RX C 

Compare Logical CLI SI C 

Compare Logical CLC SS C 

Compare (Long) CDR RR F,C 

Compare (Long) CD RXF,C 

Compare (Short) CER RR F,C 

Compare (Short) CE RX F,C 

Convert to Binary CVB RX 

Convert to Decimal CVD RX 

Diagnose SI M 

Divide DR RR 

Divide D RX 

Divide Decimal DP SS T 

Divide ( Long ) DDR RR F 

Divide (Long) DD RX F 

Divide (Short) DER RR F 

Divide (Short) DE RX F 

Edit ED SS T,C 

Edit and Mark EDMK SS T,C 

Exclusive OR XR RR C 

Exclusive OR X RX C 

Exclusive OR XI SI C 

Exclusive OR XC SS C 

Execute EX RX 

Halt I/O HIO SI CM 

Halve (Long) HDR RR F S 

Halve (Short) HER RR F S 

Insert Character IC RX P,A 

Insert Storage Key ISK RRZ M, A,S 

Load LR RR 

Load L RX P,A,S 

Load Address LA RX 

Load and Test LTR RR C 

Load and Test 

(Long) 
Load and Test 

(Short) 
Load Complement 
Load Complement 

(Long) 
Load Complement 

(Short) 
Load Halfword 
Load (Long) 
Load (Long) 
Load Multiple 
Load Negative 
Load Negative 

(Long) 
Load Negative 

(Short) 
Load Positive 
Load Positive 

(Long) 
Load Positive 

(Short) 
Load PSW 

Load (Short) LER RR F S 

Load (Short) LE RX F P,A,S 

Move MVI SI P,A 

Move MVC SS P,A 

Move Numerics MVN SS P,A 

Move with Offset MVO SS P,A 

Move Zones MVZ SS P,A 



IK 



P,A,S 

P,A 

P,A 

S 
P,A,S 

S 
P,A,S 
P,A,S,D, 
P,A,S 

P,A,S 

S, IK 
PAS, IK 
P,A,S,D, DK 

S,U,E,FK 
P,A,S,U,E,FK 

S,U,E,FK 
P,A,S,U,E,FK 

P,A, D 
P,A, D 



LTDR RRF,C S 

LTER RRF,C S 
LCR RR C 

LCDR RRF,C S 

LCER RRF,C S 

LH RX P,A,S 

LDR RR F S 

LD RX F P,A,S 

LM RS P,A,S 
LNR RR C 

LNDR RR F,C S 

LNER RRF,C S 
LPR RR C 

LPDR RRF.C S 

LPER RRF,C S 
LPSW SI LM,PAS 



EX 



15 54 

55 54 

95 54 

D5 54 

29 47 

69 47 

39 47 

79 47 

4F 31 

4E 32 

83 76 

ID 31 

5D 31 

FD 38 

2D 49 

6D 49 

3D 49 

7D 49 

DE 57 

DF 59 

17 55 

57 55 
97 55 
D7 55 
44 67 
9E 96 
24 48 
34 48 
43 56 
09 74 

18 26 

58 26 
41 56 
12 26 

22 44 



32 44 
IF 13 27 

23 44 

33 44 
48 26 
28 44 
68 44 
98 27 
11 27 

21 45 

31 45 
IF 10 27 

20 44 

30 44 

82 73 

38 44 

78 44 

92 53 

D2 53 

Dl 54 

El 40 

D3 54 
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Form A22-6821 



Multiplj' 

Multiply 

Multiply Decimal 

Multiply Halfword 

Multiply ( Long ) 

Multiply (Long) 

Multiply (Short) 

Multiply (Short) 

OR 

OR 

OR 

OR 

Pack 

Read Direct 

Set Program Mask 

Set Storage Key 

Set System Mask 

Shift Left Double 

Shift Left Double 

Logical 
Shift Left Single 
Shift Left Single 

Logical 
Shift Right Double 
Shift Right Double 

Logical 
Shift Right Single 
Shift Right Single 

Logical 
Start I/O 
Store 

Store Character 
Store Halfword 
Store (Long) 
Store Multiple 
Store (Short) 
Subtract 
Subtract 

Subtract Decimal 
Subtract Halfword 
Subtract Logical 
Subtract Logical 
Subtract Norm- 
alized ( Long ) 
Subtract Norm- 
alized (Long) 
Subtract Norm- 
alized ( Short ) 
Subtract Norm- 
alized (Short) 
Subtract Unnorm- 

alized (Long) 
Subtract Unnorm- 

alized (Long) 
Subtract Unnorm- 

alized (Short) 
Subtract Unnorm- 

alized (Short) 
Supervisor Call 

Test and Set 

Test Channel 

Test I/O 

Test Under Mask 

Translate 

Translate and Test 

Unpack 

Write Direct 

Zero and Add 



MNE- 
MONIC 

MR 

M 

MP 

MH 

MDR 

MD 

MER 

ME 

OR 

O 

OI 

OC 

PACK 

RDD 

SPM 

SSK 

SSM 

SLDA 

SLDL 
SLA 

SLL 
SRDA 

SRDL 
SRA 

SRL 

SIO 

ST 

STC 

STH 

STD 

STM 

STE 

SR 

S 

SP 

SH 

SLR 

SL 

SDR 

SD 

SER 

SE 

SWR 

SW 

SUR 

SU 

SVC 

TS 

TCH 

TIO 

TM 

TR 

TRT 

UNPK 

WRD 

ZAP 



TYPE 

RR 

RX 

SS T 

RX 

RRF 

RXF 

RRF 

RXF 

RR ( 

RX < 

SI < 



EXCEPTIONS 
S 

P,A,S 

P,A,S,D 

P,A,S 

S,U,E 
P,A,S,U,E 

S,U,E 
P,A,S,U,E 



SS 
SS 
SI 
RR 



C P,A,S 
C P,A 
G P,A 
P,A 
Y M,P,A 
L 



RRZ M, A,S 
SI M,P,A 

RS G S. 

RS S 

RS C 



IF 



IF 



CODE PG. 

IC 30 

5C 30 

FC 38 

4C 30 

2C 48 

6C 48 

3C 48 

7C 48 

16 55 

56 55 

96 55 

D6 55 

F2 39 

85 75 

04 73 

08 74 

80 74 

8F 33 

8D 60 

8B 32 



List of Instructions by Set and Feature 



Standard Instruction Set 



RS 






89 


59 


RS C 


S 




8E 


34 


RS 


S 




8C 


60 


RS C 






8A 


33 


RS 






88 


60 


SI CM 




9C 


94 


RX 


P,A,S 




50 


32 


RX 


P,A 




42 


56 


RX 


P,A,S 




40 


32 


RXF 


P,A,S 




60 


50 


RS 


P,A,S 




90 


32 


RXF 


P,A,S 




70 


50 


RR C 




IF 


IB 


29 


RX C 


P,A,S, 


IF 


5B 


29 


SS T,C 


P,A, D 


, DF 


FB 


37 


RX C 


P,A,S, 


IF 


4B 


29 


RR C 






IF 


29 


RX C 


P,A,S 




5F 


29 


RRF,C 


S,U,E,LS 


2B 


46 


RXF.C 


P,A,S,U,E,LS 


6B 


46 


RRF,C 


S,U,E,LS 


3B 


46 


RXF,C 


P,A,S,U,E,LS 


7B 


46 


RRF.C 


s, 


E,LS 


2F 


47 


RXF,C 


P,A,S, 


E,LS 


6F 


47 


RRF,C 


s, 


E.LS 


3F 


47 


RXF,C 


P,A,S, 


E,LS 


7F 


47 


RR 






OA 


74 


SI C 


P,A 




93 


74 


SI CM 




9F 


98 


SI CM 




9D 


95 


SI C 


P,A 




91 


56 


SS 


P,A 




DC 


57 


SS c 


P,A 




DD 57 


SS 


P,A 




F3 


39 


SI Y M,P,A 




84 


75 


SS T,C 


P,A, D 


, DF 


F8 


37 



NAME 

Add 

Add 

Add Halfword 

Add Logical 

Add Logical 

AND 

AND 

AND 

AND 

Branch and Link 

Branch and Link 

Branch on 

Condition 
Branch on 

Condition 
Branch on Count 
Branch on Count 
Branch on Index 

High 
Branch on Index 

Low or Equal 

Compare 
Compare 

Compare Halfword 
Compare Logical 
Compare Logical 
Compare Logical 
Compare Logical 
Convert to Binary 
Convert to Decimal 
Diagnose 
Divide 
Divide 
Exclusive OR 
Exclusive OR 
Exclusive OR 
Exclusive OR 
Execute 
Halt I/O 
Insert Character 
Load 
Load 

Load Address 
Load and Test 
Load Complement 
Load Halfword 
Load Multiple 
Load Negative 
Load Positive 
Load PSW 

Move 

Move 

Move Numerics 

Move with Offset 

Move Zones 

Multiply 

Multiply 

Multiply Halfword 

OR 

OR 

OR 

OR 

Pack 



MNEMONIC 

AR 

A 

AH 

ALR 

AL 

NR 

N 

NI 

NC 

BALR 

BAL 

BCR 



TYPE 

RR C 



BC 

BCTR 

BCT 

BXH 

BXLE 

CR 

C 

CH 

CLR 

CL 

CLC 

CLI 

CVB 

CVD 

DR 

D 

XR 

X 

XI 

XC 

EX 

HIO 

IC 

LR 

L 

LA 

LTR 

LCR 

LH 

LM 

LNR 

LPR 

LPSW 

MVI 

MVC 

MVN 

MVO 

MVZ 

MR 

M 

MH 

OR 

O 

OI 

OC 

PACK 



RX 

RX 

RR 

RX 

RR 

RX 

SI 

SS 

RR 

RX 

RR 

RX 
RR 
RX 

RS 

RS 

RR 

RX 

RX 

RR 

RX 

SS 

SI 

RX 

RX 

SI 

RR 

RX 

RR 

RX 

SI 

SS 

RX 

SI 

RX 

RR 

RX 

RX 

RR 

RR 

RX 

RS 

RR 

RR 

SI 

SI 

SS 

SS 

SS 

SS 

RR 

RX 

RX 

RR 

RX 

SI 

SS 

SS 



c 
c 

L 



CODE 
lA 

5A 
4A 
IE 
5E 
14 
54 
94 
D4 
05 
45 

07 

47 
06 
46 

86 

87 

19 
59 
49 
15 
55 
D5 
95 
4F 
4E 
83 
ID 
5D 
17 
57 
97 
D7 
44 
9E 
43 

18 
58 
41 
12 
13 
48 
98 
11 
10 
82 

92 
D2 
Dl 
Fl 
D3 
IC 
5C 
4C 
16 
56 
96 
D6 
F2 
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NAME 


MNEMONIC 


TYPE 


CODE 


Set Program Mask 


SPM 


RR L 


04 


Set System Mask 


SSM 


SI 


80 


Shift Left Double 


SLDA 


RS C 


8F 


Shift Left Single 


SLA 


RS C 


8B 


Shift Left Double 








Logical 


SLDL 


RS 


8D 


Shift Left Single 








Logical 


SLL 


RS 


89 


Shift Right Double 


SRDA 


RS C 


8E 


Shift Right Single 


SRA 


RS C 


8A 


Shift Right Double 








Logical 


SRDL 


RS 


8C 


Shift Right Single 








Logical 


SRL 


RS 


88 


Start I/O 


SIO 


SI C 


9C 


Store 


ST 


RX 


50 


Store Character 


STC 


RX 


42 


Store Halfword 


STH 


RX 


40 


Store Multiple 


STM 


RS 


90 


Subtract 


SR 


RR C 


IB 


Subtract 


S 


RX C 


5B 


Subtract Halfword 


SH 


RX C 


4B 


Subtract Logical 


SLR 


RR C 


IF 


Subtract Logical 


SL 


RX C 


5F 


Supervisor Call 


SVC 


RR 


OA 


Test and Set 


TS 


SI C 


93 


Test Channel 


TCH 


SI C 


9F 


Test I/O 


TIO 


SI C 


9D 


Test Under Mask 


TM 


SI C 


91 


Translate 


TR 


SS 


DC 


Translate and Test 


TRT 


SS C 


DD 


Unpack 


UNPK 


SS 


F3 


Floating-Point Feature Instructions 




NAME 


MNEMONIC 


TYPE 


CODE 


Add Normalized 








(Long) 


ADR 


RRF,C 


2A 


Add Normalized 








(Long) 


AD 


RXF,C 


6A 


Add Normalized 








(Short) 


AER 


RRF,C 


3A 


Add Normalized 








(Short) 


AE 


RXF.C 


7A 


Add Unnorm- 








alized (Long) 


AWR 


RRF,C 


2E 


Add Unnorm- 








alized (Long) 


AW 


RXF,C 


SE 


Add Unnorm- 








alized (Short) 


AUR 


RRF.C 


3E 


Add Unnorm- 








alized (Short) 


AU 


RXF.C 


7E 


Compare (Long) 


CDR 


RRF,C 


29 


Compare ( Long ) 


CD 


RX F,C 


69 


Compare (Short) 


CER 


RRF.C 


39 


Compare (Short) 


CE 


RXF,C 


79 


Divide (Long) 


DDR 


RRF 


2D 


Divide (Long) 


DD 


RXF 


6D 


Divide (Short) 


DER 


RRF 


3D 


Divide (Short) 


DE 


RXF 


7D 


Halve Long 


HDR 


RRF 


24 


Halve (Short) 


HER 


RRF 


34 


Load and Test 








(Long) 


LTDR 


RRF.C 


22 


Load and Test 








(Short) 


LTER 


RRF.C 


32 


Load Complement 








(Long) 


LCDR 


RRF,C 


23 


Load Complement 








(Short) 


LCER 


RRF.C 


33 



NAME 


MNEMONIC 


TYPE 


CODE 


Load ( Long ) 


LDR 


RRF 


28 


Load (Long) 


LD 


RXF 


68 


Load Negative 








(Long) 


LNDR 


RRF,C 


21 


Load Negative 








(Short) 


LNER 


RRF,C 


31 


Load Positive 








(Long) 


LPDR 


RRF,C 


20 


Load Positive 








(Short) 


LPER 


RRF.C 


30 


Load (Short) 


LER 


RRF 


38 


Load (Short) 


LE 


RXF 


78 


Multiply (Long) 


MDR 


RRF 


2C 


Multiply (Long) 


MD 


RXF 


6C 


Multiply (Short) 


MER 


RRF 


3C 


Multiply (Short) 


ME 


RXF 


7C 


Store (Long) 


STD 


RXF 


60 


Store (Short) 


STE 


RXF 


70 


Subtract Norm- 








alized ( Long ) 


SDR 


RRF,C 


2B 


Subtract Norm- 








alized ( Long ) 


SD 


RXF.C 


6B 


Subtract Norm- 








alized (Short) 


SER 


RRF,C 


SB 


Subtract Norm- 








alized (Short) 


SE 


RXF.C 


7B 


Subtract Unnorm- 








alized ( Long ) 


SWR 


RRF.C 


2F 


Subtract Unnorm- 








alized (Long) 


SW 


RXF.C 


6F 


Subtract Unnorm- 








alized (Short) 


SUR 


RRF.C 


3F 


Subtract Unnorm- 








alized (Short) 


SU 


RXF.C 


7F 


Decimal Feature Instructions 






NAME 


MNEMONIC 


TYPE 


CODI 


Add Decimal 


AP 


SS T,C 


FA 


Compare Decimal 


CP 


SS T,C 


F9 


Divide Decimal 


DP 


SS T 


FD 


Edit 


ED 


SS T,C 


DE 


Edit and Mark 


EDMK 


SS T,C 


DF 


Multiply Decimal 


MP 


SS T 


FC 


Subtract Decimal 


SP 


SS T,C 


FB 


Zero and Add 


ZAP 


SS T.C 


F8 



Commercial Instruction Set 

The commercial instruction set includes the instructions of both 
the standard instruction set and the decimal feature. 

Protection Feature Instructions 

NAME MNEMONIC TYPE CODE 

Insert Storage Key ISK RRZ 09 

Set Storage Key SSK RRZ 08 

Scientific Instruction Set 

The scientific instruction set includes the instructions of both 
the standard instruction set and the floating-point feature. 

Universal Instruction Set 

When the .instructions associated with storage protection are 
added to the commercial and scientific features, a universal 
instruction set is obtained. 

Direct Control Feature Instructions 

NAME MNEMONIC TYPE CODE 

Read Direct RDD SI Y 85 

Write Direct WRD SI Y 84 
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List of Instructions by Operation Code 



::oDE 


MNEMONIC 


PAGE 


04 


SPM 


73 


05 


BALR 


66 


06 


BCTR 


66 


07 


BCR 


65 


08 


SSK 


74 


09 


ISK 


74 


OA 


SVC 


74 


10 


LPR 


27 


11 


LNR 


27 


12 


LTR 


26 


13 


LCR 


27 


14 


NR 


55 


15 


CLR 


54 


16 


OR 


55 


17 


XR 


55 


18 


LR 


26 


19 


CR 


30 


lA 


AR 


28 


IB 


SR 


29 


IC 


MR 


30 


ID 


DR 


31 


IE 


ALR 


28 


IF 


SLR 


29 


20 


LPDR 


44 


21 


LNDR 


45 


22 


LTDR 


44 


23 


LCDR 


44 


24 


HDR 


48 


28 


LDR 


44 


29 


CDR 


47 


2A 


ADR 


45 


2B 


SDR 


46 


2C 


MDR 


48 


2D 


DDR 


49 


2E 


AWR 


46 


2F 


SWR 


47 


30 


LPER 


44 


31 


LNER 


45 


32 


LTER 


44 


33 


LCER 


44 


34 


HER 


48 


38 


LER 


44 


39 


CER 


47 


3A 


AER 


45 


3B 


SER 


46 


3C 


MER 


48 


3D 


DER 


49 


3E 


AUR 


46 


3F 


SUR 


47 


40 


STH 


32 


41 


LA 


56 


42 


STC 


56 


43 


IC 


56 


44 


EX 


67 


45 


BAL 


66 


46 


BCT 


66 


47 


BC 


65 


48 


LH 


26 


49 


CH 


30 


4A 


AH 


28 


4B 


SH 


29 


4C 


MH 


30 


4E 


CVD 


32 


4F 


CVB 


31 


50 


ST 


32 


54 


N 


55 


55 


CL 


54 


56 


O 


55 


57 


X 


55 


58 


L 


26 



CODE 


MNEMONIC 


PAG 


59 


C 


30 


5A 


A 


28 


5B 


S 


29 


5C 


M 


30 


5D 


D 


31 


5E 


AL 


28 


5F 


SL 


29 


60 


STD 


50 


68 


LD 


44 


69 


CD 


47 


6A 


AD 


45 


6B 


SD 


46 


6C 


MD 


48 


6D 


DD 


49 


6E 


AW 


46 


6F 


SW 


47 


70 


STE 


50 


78 


LE 


44 


79 


CE 


47 


7A 


AE 


45 


7B 


SE 


46 


7C 


ME 


48 


7D 


DE 


49 


7E 


AU 


46 


7F 


SU 


47 


80 


SSM 


74 


82 


LPSW 


73 


83 




76 


84 


WRD 


75 


85 


RDD 


75 


86 


BXH 


66 


87 


BXLE 


66 


88 


SRL 


60 


89 


SLL 


59 


8A 


SRA 


33 


8B 


SLA 


32 


8C 


SRDL 


60 


8D 


SLDL 


60 


8E 


SRDA 


34 


8F 


SLDA 


33 


90 


STM 


32 


91 


TM 


56 


92 


MVI 


53 


93 


TS 


74 


94 


NX 


55 


95 


CLI 


54 


96 


or 


55 


97 


XI 


55 


98 


LM 


27 


9C 


SIO 


94 


9D 


TIO 


95 


9E 


HIO 


96 


9F 


TCH 


98 


Dl 


MVN 


54 


D2 


MVC 


53 


t)3 


MVZ 


54 


D4 


NC 


55 


D5 


CLC 


54 


D6 


OC 


55 


D7 


XC 


55 


DC 


TR 


57 


DD 


TRT 


57 


DE 


ED 


57 


DF 


EDMK 


59 


Fl 


MVO 


40 


F2 


PACK 


39 


F3 


UNPK 


39 


F8 


ZAP 


37 


F9 


CP 


38 


FA 


AP 


37 


FB 


SP 


37 


FC 


MP 


38 


FD 


DP 


38 
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Where more than one page-reference is given, major references 
appear first and in italic type. 

Access to main storage, right of 70, 17 

Adapter, channel-to-channel 84, 85 

ADD DECIMAL instruction (AP) 

Description 37 

Example of use 136.2 

ADD HALFWORD instruction (AH) 

Description 28 

Example of use 129 

ADD instruction (AR, A) 28 

ADD LOGICAL instruction (ALR, AL) 28 

ADD NORMALIZED instruction (ADR, AD, AER, AE) 

Description 45 

Example of use 136.5 

ADD UNNORMALlZED instruction (AWR, AW, AUR, AU) 

Description 46 

Example of use 136.5 

Address 

Generation 13 

Of channel address word (CAW) 15 

Of channel status word (CSW) 15 

Of diagnostic scan-out area 15 

Of initial program loading CCWl 15 

Of initial program loading CCW2 15 

Of old ana new program status words (PSW) 15 

Of timer 15 

Switches 126 

Address-compare switch on system control panel 126 

Addressing 

Channels 88, 89, 94, 112 

Control units 89, 94 112 

Exception 79,157-158 

I/O devices 88, 89, 94, 112 

Limitations 8 

Nonexistent areas 102 

Of locations in main and shared storage 8 

Of registers ...:., 9 

Of subchannels and shared subchannels 89 

Wraparound feature with maximum storage ...8, 101 

Altering of an instruction by EXECUTE 67, 128 

Alternate-prefix light on system control panel 126 

AND instruction (NR, N, NI, NC) 

Description 55 

Example of use 133, 136.4 

Appendixes A-G 127-167 

Arithmetic 

Decimal 35,10 

Fixed-point 24,10 

Floating-point 41, 11 

Arithmetic and logical unit 10 

ASCII(A) bit (in PSW) 71,15 

ASCII-8 

( See "USA standard code for information interchange 
extended to eight bits." ) 

Assembly language, symbolic operand designations for 
System/360 
( See individual instruction descriptions. ) 

Attention condition 113, 111 



Base address 13 

Basic unit of information (the byte) 8 

Bits 

In a byte 8 

Modifier 100 

Blocking of data 99 



Boimdary, integral 8 

Branch address 63, 64 

BRANCH AND LINK instruction (BALR, BAL) 

Description 66 

Example of use 127 

BRANCH ON CONDITION instruction (BCR, BC) 

Description 65 

Example of use 127 

BRANCH ON COUNT instruction (BCTR, BCT) 

Description 66 

Example of use 128 

BRANCH ON INDEX HIGH instruction (BXH) 

Description 66 

Example of use 128 

BRANCH ON INDEX LOW OR EQUAL instruction 

(BXLE) 66 

Branching 

As a change in sequential operations 62 

Decision making in 63 

Definition 62 

Examples 127 

Instruction formats 64 

Instructions 64-67 

Sequential operation exceptions in 62 

Uses 14 

Burst mode of operation 85, 18 

Bus-out check (sense bit) 106 

Busy condition 114 

Bytes 8 



CAW (channel address word) 99,19,87 

ccw 

( See "channel command word.") 

Central processing unit (CPU) 8 

Chain-command flag (in CCW) 99,101 

Chain-data flag (in CCW) 99, 101 

Chaining 

Of commands 103 

Of data 101 

Chaining check condition 118 

Channel 

Address 89 

Availability 90 

Burst mode 85, 18 

Commands 105,99 

Compatibility of operation 88 

Data rate capabilities 88 

Equipment error 93, 164 

Facilities provided 18 

Function 85 

Modes of operation 85, 18 

Multiplex mode 85, 18 

Programming error 93^ 163 

Subchannels 86.89 

Channel address word (CAW) 99,19,87 

Channel command word ( CCW ) 

Composition 99 

Types 19 

Channel control check condition 118 

Channel data check condition 118 

Channel end condition 115, 111 

Channel operation, possible differences among models in 

normal 163 

Channel status conditions 

Chaining check 118 

Channel control check 118 

Channel data check 118 
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Incorrect length 117 

Interface control check 118 

Program check 117 

Program-controlled interruption 116 

Protection check 117 

Channel status word ( CSW ) 

Command address 119 

Content 113,118 

Count 120 

Protection key 119 

Status bits 120 

Channel-to-channel adapter 84, 85 

Characteristic in floating-point operands 41,11,138 

Check bit (parity bit) 8 

Classes of instructions 154 

Clock, timer as a real-time 82 

Code 

EBCDIC 12,150.2 

Charts 150.1,150.3 

Command 100 

Instruction-length 71, 156, 162 

Interruption 15. 71, 77 

Operation 12, 13, 154, 167.1 

USASCII-8 12, 36, 150 

Code, condition 

( See "condition code." ) 

Command 

Chaining 103 

Code in CCW 100 

Control 106,20 

Read 105,19 

Read Backward 105, 20 

Sense 106,20 

Transfer in Channel 107,20 

Write 105,19 

Command address 

Of CAW 99 

Of CSW 113, 119 

Command immediate ( or immediate operation ) 106, 108 

Command reject (sense bit) 106 

Commercial instruction set 167,5 

COMPARE DECIMAL instruction (CP) 

Description 38 

Example of use 136.2 

COMPARE HALFWORD instruction (CH) 

Description 30 

Example of use 129 

COMPARE instruction (CR, C) 30 

COMPARE instruction (CDR. CD, CER, CE) 

Description 47 

Example of use 136.5 

COMPARE LOGICAL instruction (CLR, CL, CLI, CLC) 

Description 54 

Example of use 132 

Compatibility 

Advantages -5 

As a design feature 5 

Limitations 5 

Of models 5 

Of operation 88 

Components of an address 13 

Condition code 

As part of PSW 71 

In branching 14, 63 

In decimal arithmetic operations 36 

In fixed-point arithmetic operations 25 

In floating-point arithmetic operations 42 

In I/O operations 92 

In logical operations 52 

For I/O instructions according to states of I/O system . . 92 
Summaiy 65, 155 

Control command 106,20, 100 

Control panel 

(See system control panel.") 

Control section in CPU 9 

Control unit 

Address in device address 89 

Address in I/O old PSW 112 

Attachment in system 7, 84 

Functions 84, 18 

Indistinguishable from I/O devices 18,85 



Selection 84 

Shared by I/O devices 85, 89 

Control unit end condition 114,111 

Control word formats 153 

CONVERT TO BINARY instruction (CVB) 

Description 31 

Example of use 130 

CONVERT TO DECIMAL instruction (CVD) 

Description 32 

Example of use 130 

Count 

In CCW 100 

In CSW 120 

Counter, instruction ( instruction address portion of 

current PSW) 71 

CPU (central processing unit) 8 

CPU facilities 8 

CSW 

( See "channel status word." ) 



Data 

Address in CCW 99 

Blocking 99 

Chaining JOi, 87 

Chaining ( as affected by compatibility ) 88, 163 

Channel prefetching and buffering of 101 

Exception 80,160 

Positioning of in main storage 8 

Switches 126 

Data check (sense bit) 107 

Data format 

Decimal arithmetic 35 

Fixed-point arithmetic 24 

Floating-point arithmetic 41 

Logical operations 51 

Summary 151 

Data rate (as affected by compatibility) 88 

Data transfer 

Basic procedure for a 21 

Termination of a 109 

Decimal arithmetic 

Application 10 

Condition-code settings 36 

Data format 35 

Examples 136.2 

Exceptions 40 

Instruction formats 36 

Instructions 36-40 

Number representation 35 

Packed and zoned formats 35 

Representation in USASCII-8 and EBCDIC 11,36 

Decimal feature instructions 167 

Decimal fields, shifting of 136.4,40 

Decimal-divide exception 40, 80 

Decimal-overflow exception 40, 80i, 160 

Decimal-to-hexadecimal, hexadecimal-to-decimal 

conversion 146-147 

Decision-making by BRANCH ON CONDITION 

instruction 65, 14, 63 

Design feature 

Compatibility as a 5 

General-purpose system as a 5 

Multisystem operation as a 6,17 

Solid logic tecnnology as a 6 

Supervisory program as a 5 

System alerts as a 6 

Device 

Accessibility 89 

Addressing 88 

Address in I/O old PSW 112 

Address in START I/O 94 

Error condition 93 

General information 84, 18 

Device end condition 115, 111 

DIAGNOSE instruction 76, 162 

Diagnostic procedure (initiated by a machine check) 16 

Diagnostic scan-out area, address of 15 
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DiflFerences among models, possible 161 

Digit selector in editing 58 

Direct control feature 17,82 

Direct control feature instructions 167 

Displacement portion of address 14 

Display key on system control panel 126 

DIVIDE DECIMAL instruction (DP) 

Description 38 

Example of use 136.3 

DIVIDE instruction (DR, D) 

Description 31 

Example of use 130 

DIVIDE instruction (DDR, DD, DER, DE) 49 

Double word 8 



EBCDIC (extended binary-coded-decimal interchange 

code) 12,36,150.2 

EDIT AND MARK instruction (EDMK) 

Description 60 

Example of use 136.2 

EDIT instruction (ED) 

Description 57 

Example of use 136.1 

Emergency pull switch on system control panel 124 

Equipment check (sense bit) 107 

Error 

Channel equipment 93, 164 

Channel programming 93, 163 

Device 93 

Examples of instruction use ( see also individual 

instruction names) 127 

Exception conditions (causes of program interruptions) 

During decimal arithmetic operations 40 

During EXECUTE operations 67 

During fixed-point arithmetic operations 34 

During floating-point arithmetic operations 50 

During logical operations 61 

During sequential operations 62 

During status-switching operations 76 

Summary of 79, 16 

Excess-64 binary notation 41, 138 

EXCLUSIVE OR instruction (XR, X, XI, XC) 

Description 55 

Example of use 134 

Execute exception 79 

EXECUTE instruction (EX) 

Description 67 

Example of use 128 

Execute operation, exceptions during 67 

Execution of instructions, possible differences among 

models in 161 

Execution of programs 12 

Exponent in a floating-point number 41, 11, 138 

Exponent-overflow exception 50,80, 160 

Exponent-underflow exception 50,80, 161 

Extended binary-coded-decimal interchange code 

(EBCDIC) 12,36,149 

External interruptions 81, 16 

External signal 82 

External-start lines ( initial program loading ) 123 



Feature and instruction set, list of instructions by 166 

Features 

Design 5 

Direct control 17 

Multisystem 6, 17 

Protection 17,70 

Timer 17, 8J 

Fetch protection 17, 70, 156-157 

Field lengths 

( See "instruction formats." ) 

Fill character in editing 58 

Fixed-length logical information 51 



Fixed-point arithmetic 

Condition code settings 25 

Data format 24 

Examples 129 

Exceptions 34 

General description 10 

Instruction formats 25 

Instructions 26-34 

Number representation 24 

Summary or instructions 26 

Use of two's complement in 24, 137 

Fixed-point-divide exception 34, 80, 160 

Fixed-point-overflow exception 34,80, 160 

Flag in CCW 

As defined for each type of command 105 

Chain-command 99 

Chain-data 99 

Program-controUed-interruption (PCI) 100 

Skip 100 

Suppress-length-indication (SLI) 99 

Floating-point arithmetic 

Condition code settings 42 

Data format 41 

Examples 136.4 

Exceptions 50 

General description 11 

Instruction formats 42 

Instructions 43-50 

Normalization 42 

Number representation 41 

Purpose 41 

Registers • 9 

Floating-point numbers, converting from decimal 

numbers to 138 

Floating-point register 

Identification 9 

Number 9 

Size 10 

Use 9 

Floating-point-divide exception 50,80, 161 

Floating-point-feature instructions, listing of 167 

Format, data 

(See "data format.") 

Format, I/O 93 

Format, information 7 

Format, instruction 

( See "instruction formats." ) 

Formats, basic instruction 12 

FuUword (word) 8 

Functions that may differ among models 161-164 

General registers 9 

General-purpose system , 5 

Generating of addresses 13 

Guard digit (in floating-point arithmetic) 41 

Halfword 8 

HALT I/O instruction (HIO) 96,19,110 

HALVE instruction (HDR, HER) 48 

Hexadecimal representation 12, 151 

Hexadecimal tables for 

Addition 148 

Direct conversion 141-145 

Fraction conversion 147 

Integer conversion 146 

Powers of 16 146 

Multiplication , 148 

Subtraction 148 

ILC (instruction length code) 71,77 

Immediate operands - 13 

Incorrect length condition 117 
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Index portion of address 14 

Information formats 7 

Initial program loading (IPL) 123,22 

Initial program loading CCWl 15 

Initial program loading CCW2 15 

Initial program loading PSW 15 

Input/output (I/O) 

Basic procedure for a data transfer operation 21,22 

Channels 85, 18 

Commands 105, 19 

Control 88 

Control vmits 84, 18 

Execution 98 

General description 6 

Initiation 87, 19 

Instruction format 93 

Instructions 93-98 

Interface 84, 6, 18 

Interruptions ..111,20,77 

Operations 87 

Resetting of system 91 

Termination 108,20 

Input/output device 

(See "device.") 
Input/output system 

Availability 90 

Operation of 87 

INSERT CHARACTER instruction (IC) 56 

INSERT STORAGE KEY instruction (ISK) 74 

Instruction 

Add (AR, A) 28 

Add decimal (AP) 37,136.2 

Add halfword (AH) 28,129 

Add logical (ALR, AL) 28 

Add normalized (ADR, AD, AER, AE) 45,136.5 

Add unnormalized (AWR, AW, AUR, AU) 46,136.5 

AND (NR, N, NI, NC) 55,133,136.4 

Branch and link (BALR, BAL) 66, 127 

Branch on condition (BCR, BC) 65,14,127 

Branch on count (BCTR, BCT) 66,15,128 

Branch on index high (BXH) ' 66, 128 

Branch on index low or equal (BXLE) 66 

Compare (CR, C) 30 

Compare (CDR, CD, CER; CE) 47,136.5 

Compare decimal (CP) 38,136.2 

Compare halfword (CH) 30,129 

Compare logical (CLR, CL, CLI, CLC) 54,132 

Convert to binary (CVB) 31, 130 

Convert to decimal (CVD) 32,130 

Diagnose 32 

Divide (DR, D) 31,130 

Divide (DDR, DD, DER, DE) 49 

Divide decimal (DP) 38, 136.3 

Edit (ED) 57, 136.1 

Edit and mark (EDMK) 60, 136.2 

Exclusive OR (XR, X, XI, XC) 55, 134 

Execute (EX) 67, 128 

Halt I/O 96,110 

Halve (HDR, HER) 48 

Insert character (IC) 56 

Insert storage key (ISK) 74,136.6 

Load (LR, L) 26,129 

Load (LDR, LD) 44 

Load address (LA) 56, 135 

Load and test (LTR) 26 

Load and test (LTDR, LTER) 44 

Load complement (LCR) 27 

Load complement (LCDR, LCER) 44 

Load halfword (LH) 26,129 

Load multiple (LM) 27 

Load negative (LNR) 27 

Load negative (LNDR, LNER) 45 

Load positive (LPR) 27 

Load positive (LPDR, LPER) 44 

Load PSW (LPSW) 73 

Move (MVI, MVC) 53,129,131,136.4 

Move numerics (MVN) 54, 132, 136.4 

Move with offset (MVO) 40,136.4 

Move zones (MVZ) 54,132 

Multiply (MR, M) 30,130 



Multiply (MDR, MD, MER, ME) 48 

Multiply decimal (MP) 38, 136.3 

Multiply halfword (MH) 30,130 

OR (OR, O, OI, OC) 55, 133 

Pack (PACK) 39, 136.3 

Read direct (RDD) 75 

Set program mask (SPM) 73 

Set storage key (SSK) 74,136.6 

Set system mask (SSM) 74 

Shift left double (SLDA) 33, 131 

Shift left double (SLDL) 60 

Shift left single (SLA) , 32, 131 

Shift left single (SLL) 60 

Shift right double (SRDA) 34 

Shift right double (SRDL) 61 

Shift right single (SRA) 33 

Shift right single (SRL) 60 

Start I/O (SIO) 94 

Store (ST) 32 

Store (STD, STE) 50 

Store character (STC) 56 

Store halfword (STH) 32 

Store multiple (STM) 32, 131 

Subtract (SR, S) 29 

Subtract decimal (SP) : 37 

Subtract halfword (SH) 29 

Subtract logical (SLR, SL) 29 

Subtract normalized (SDR, SD, SER, SE) 46 

Subtract unnormalized (SWR, SW, SUR, SU) 47 

Supervisor caU (SVC) 74,136.5 

Test and set (TS) 74,136.6 

Test channel (TCH) 98 

Test I/O (TIO) 95 

Test under mask (TM) 56,135 

Translate (TR) 57, 135 

Translate and test (TRT) 57,136 

Unpack (UNPK) 39, 136.4 

Write direct (WRD) 75 

Zero and add (ZAP) 37,136.2 

Instruction address (in PSW) 72,15 

Instruction counter ( instruction address portion of 

current PSW) 71 

Instruction execution, possible differences among models in 161 
Instruction execution, sequential 

( See "sequential execution of instructions." ) 
Instruction formats 

Basic 12 

Branching 64 

Decimal arithmetic 36 

Fixed-point arithmetic 25 

Floating-point arithmetic 42 

General information about 12 

Input/output 93 

Logical operations 52 

Status switching 72 

Summary of 152, 154 

Instruction information, summary of 165 

Instruction length code (ILC) 71,77, 156, 162 

Instruction sets 165-167, 5 

Instruction termination, possible differences among 

models in 162 

Instructions, examples of the use of 127 

Integral boundary 8 

Interface control check condition 118 

Interface, I/O 6,18,84 

Interleaving of main storage 7 

Interrupt key on system control panel 124,82 

Interruptible and masked program states 69, 17 

Interruption 

Action 77 

Code (in PSW) 15,71,77 

Exceptions causing 79 

External 81, 16 

I/O ill, 15, 20-22, 78 

Location of instruction being interpreted at 78 

Machine check 82, 16 

Masking 77,15 

Priority 83,16 

Program 79, 16 

Program-controlled 104, 116 
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Purpose 77, 15 

Sources , 78 

Supervisor call 80, 16 

Interruption pending (state of the I/O system) 90 

Interval timer 
(See "timer.") 

Intervention required (sense bit) 107 

I/O 

( See "input/output." ) 

I/O device 

( See "device." ) 

IPL (initial program loading) 123,22 

IPL via external-start lines 123 



Key in storage 17,70 

Key, protection 

( See "protection key." ) 
Keys and lights on system control panel 124-126 



Length specifications 

( See "instruction formats." ) 

Limitations of addressing 8 

LOAD ADDRESS instruction (LA) 

Description 56 

Example of use 135 

LOAD AND TEST instruction (LTR) 26 

LOAD AND TEST instruction ( LTDR, LTER ) 44 

LOAD COMPLEMENT instruction (LCR) 27 

LOAD COMPLEMENT instruction (LCDR, LCER) 44 

LOAD HALFWORD instruction (LH) 

Description 26 

Example of use 129 

LOAD instruction (LR, L) 

Description 26 

Example of use 129 

LOAD instruction (LDR, LD) 44 

Load key on system control panel 125 

Load light on system control panel 124 

LOAD MULTIPLE instruction (LM) 27 

LOAD NEGATIVE instruction (LNR) 27 

LOAD NEGATIVE instruction (LNDR, LNER) 45 

LOAD POSITIVE instruction (LPR) 27 

LOAD POSITIVE instruction (LPDR, LPER) 44 

LOAD PSW instruction (LPSW) 73 

Load-unit switches on system control panel 124 

Loading of initial program information 22, 123 

Locations subject to protection 70 

Logical operations 

Condition code settings 52 

Data formats 51 

Examples 131 

Exceptions 61 

General description 12 

Instruction formats 52 

Instructions 53-60 

Logginc of machine-error information 83,6 

Long floating-point number 41 



Wraparound with maximum addressable 8, 101 

Malfunction (selective) reset in I/O system 92 

Manual light on system control panel 124 

Manual operation of system 

( See "system control panel." ) 
Mask position values used in BRANCH ON CONDITION 65 

Masked and interruptible program states 17,69 

Masks in the PSW 71 

Message character in editing 58 

Mnemonic listing in alphabetic list of instructions 165, 166 

Models, functions that may differ among 161-164 

Modification of an instruction by EXECUTE 67, 128 

Modifier bits in CCW command code 100 

Monitoring accesses to main storage by use of the 

protection features 70, 17 

MOVE instruction (MVI, MVC) 

Description 53 

Examples of use 131,129,136.4 

MOVE NUMERICS instruction (MVN) 

Description 53 

Examples of use 132,136.4 

MOVE WITH OFFSET instruction (MVO) 

Description 40 

Example of use 132 

MOVE ZONES instruction (MVZ) 

Description 54 

Example of use 132 

Multiplex mode of operation 85, 18 

Multiplexor channel 

Addressing 89 

Description 86 

Location in system structure 6 

Operating modes 86, 18 

MULTIPLY DECIMAL instruction (MP) 

Description 38 

Example of use 136.3 

MULTIPLY HALFWORD instruction (MH) 

Description 30 

Example of use 130 

MULTIPLY instruction (MR, M) 

Description 30 

Example of use 130 

MULTIPLY instruction ( MDR, MD, MER, ME ) 48 

Multisystem operation 72, 6, 17 



Normalization (in floating-point arithmetic) 42 

Not available ( a general designation for three states of 

the I/O system) 90 

Not operational (state of the I/O system) 90 

Number bases, transition between by the use of 

conversion instructions 10 

Number representation 

Decimal arithmetic 35 

Fixed-point arithmetic 24 

floating-point arithmetic 41 

Numbering 

Bits of a byte 8 

Of byte locations in main storage 8 

Numeric in zoned decimal data 35 



Machine check interruption 82, 16, 162 

Machine-check mask 71 

Machine errors, handling of 82, 16 

Main storage 

Addressing 8 

Channel command word (CCW) definition of 100 

Controlled sharing of by TEST AND SET 74, 136.6 

In the system structure 7 

Information formats 7 

Information positioning 8 

Permanent assignments in 15 

Protection 70,17 

Sharing of 8 

Size 8 



Op code (operation code) 12,13,154,167.1 

Operands in addressing 13 

Operating and stopped program states 69, 16 

Operation code 12, 13, 154, 167.1 

Operation exception 79 

Operator control section of system control panel 123 

Operator intervention section of system control panel 125 

OR instruction ( OR, O, OI, OC ) 

Description 55 

Example of use 133 

Orders 106,20 

Overflow 

Fixed-point 24,34,80 

Decimal 40,80 

Overrun (sense bit) 107 
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PACK instruction (PACK) 39 

Packed decimal number 11,35 

Parity bit (check bit) 8 

Pattern character in editing 58 

Permanent-storage assignments 15, 155 

Postnormalization (in floating-point arithmetic) 42 

Power transitions, effect on main storage of 7 

Power-olf key on system control panel 124 

Power-on key on system control panel 124 

Prefix (used in direct address relocation), 12-bit 18 

Prefix-select key-switch on system control panel 125 

Prenormalization (in floating-point arithmetic) 42 

Priority of interruptions 83,16 

Privileged instructions, summary of 156 

Privileged-operation exception ., 79 

Problem and supervisor program states 68, 17 

Problem state bit (in PSW) 71, 15 

Program check condition 117 

Program errors, handling of 79,16 

Program execution 12 

Program interruptions 79, 16, 156-161 

Program mask 71 

Program states 68, 16 

Program status word (PSW) 71,15 

Program-controlled interruption (PCI) 

Bit in CSW 116, 164 

Flag in CCW 100, 163, 164 

General discussion 104 

Program-controlled-interruption condition 116 

Propagating the sign-bit value in halfword 

operations 24,26,28,29,30 

Protection 

General discussion 70, 17 

Instructions subject to store and fetch protection 156-157 

Instructions subject to store protection 156 

Protection check condition 117 

Protection exception 79 

Protection key 

In channel address word (CAW) 99 

In channel status word (CSW) 119 

In program status word (PSW) 71 

PSW (program status word) 71,15 



Radixes, transition between by the use of conversion 

instnictions 10 

Rate switch on system control panel 125 

Read Backward command 105, 20, 98 

Read command 105, 19,98 

READ DIRECT instruction (RDD) 75 

Real-time clock, timer as a 82 

Register-and-indexed-storage operations 12 

Register-and-storage operations 12 

Register-to-register operations 12 

Registers 

( See "general registers" and "floating-point registers." ) 
Representation of numbers 

(See "number representation.") 

Resetting of I/O system 91 

Result condition in editing 58 

Right of access to main storage 70,17 

RR (register-to-register) instruction format 12 

RS (register-and-storage) instruction format 12 

Running and wait program states 68,17 

RX (register-and-indexed-storage) instruction format 12 



Scientific instruction set 167,5 

Selector channel 

Addressing 89 

Description 86 

Location in system structure 6 

Operating mode 86 

Sense command 106, 20, 98 

Sense information and operation 106 



Sequential execution of instructions 

Change in by branching 62, 14 

Change in by interruptions 77 

Change in by manual intervention 122 

Change in by status switching 68 

Controlled bv PSW 15 

Initiation and termination of from system control panel 122 

Normal 14 

Set and feature, list of instructions by instruction 166 

Set IC key on system control panel 126 

SET PROGRAM MASK instruction (SPM) 73 

SET STORAGE KEY instruction (SSK) 

Description 74 

Example of use 136.6 

SET SYSTEM MASK instruction (SSM) 74 

Shared and nonshared control units 85, 89 

Shared I/O 6,7 

Shared main storage 7,18,72,82 

Shared subchannels 89 

SHIFT LEFT DOUBLE instruction (SLDA) 

Description 33 

Example of use 131 

SHIFT LEFT DOUBLE instruction (SLDL) 60 

SHIFT LEFT SINGLE instruction (SLA) 

Description 32 

Example of use 131 

SHIFT LEFT SINGLE instruction (SLL) 60 

SHIFT RIGHT DOUBLE instruction (SRDA) 34 

SHIFT RIGHT DOUBLE instruction (SRDL) 61 

SHIFT RIGHT SINGLE instruction (SRA) 33 

SHIFT RIGHT SINGLE instruction (SRL) 60 

Short floating-point number 41 

SI ( storage-and-immediate-operand ) instruction format .... 12 

Sign and zone codes used in decimal arithmetic 36 

Sign change in fixed-point arithmetic 25 

Significance exception 80, 161 

Significance indicator in editing 58 

Significance starter in editing 58 

Skip flag in CCW 100 

Skipping 103 

Source digit in editing 58 

Specification exception 80, 158-159 

SS (storage-to-storage) instruction format 12 

Standard instruction set 166,5 

START I/O data transfer example 21,22 

START I/O instruction (SIO) 94 

Start key on system control panel 125 

States of I/O system 89 

States, program 68, 16 

Status conditions 

( See "unit status condition" and "channel status condition." ) 

Status modifier condition 113 

Status switching 

Description 68 

Examples 136.5 

Exceptions 76 

In multisystem operation 72 

Instruction formats 72 

Instructions 73-76 

Program-state alternatives 68 

Program status word (PSW) 71 

Protection of storage 70 

Stop key on system control panel 125 

Stopped, and operating program states 69, 16 

Storage 

( See "main storage." ) 

Storage protection 70, 17, 156-157 

Storage, key in 70, 17 

Storage-and-inmiediate-operand operations 12 

Storage-select switch on system control panel 126 

Storage-to-storage operations 12 

Store-and-display functions of system control panel 122,22 

STORE CHARACTER instruction (STC) 56 

STORE HALFWORD instruction (STH) 32 

STORE instruction (ST) .: 32 

STORE instruction (STD, STE) 50 

Store key on system control panel 126 

STORE MULTIPLE instruction (STM) 

Description 32 

Example of use 131 
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Store protection 70, 17, 156-157 

Subchannels and shared subchannels 86,89 

SUBTRACT DECIMAL instruction (SP) 37 

SUBTRACT HALFWORD instruction (SH) 29 

SUBTRACT instruction (SR, S) 29 

SUBTRACT LOGICAL instruction ( SLR, SL ) 29 

SUBTRACT NORMALIZED instruction (SDR, SD, SER, 

SE) 46 

SUBTRACT UNNORMALIZED instruction (SWR, SW, 

SUR, SU) 47 

Supervisor and problem program states 68, 17 

SUPERVISOR CALL instruction (SVC) 

Description 74 

Example of use 136.5 

Supervisor call interruption 80 

Supervisory (system) program 5 

Suppress-length-indication (SLI) flag (in CCW) 99 

Suppression and termination of instructions by interruption 78 

Switches on system control panel 123-126 

System alerts 6 

System control panel 

Functions 122,21 

Operator control section 123,22 

Operator intervention section 125,23 

Possible differences among models in 163 

System control section in CPU 9 

System light on system control panel 124 

System mask (in PSW) 71 

System (supervisory) program 5 

System structure 7 

System-reset function of system control panel 122 

System-reset key on system control panel 125 



TRANSLATE AND TEST instruction (TRT) 

Description 57 

Example of use 136 

TRANSLATE instruction (TR) 

Description 57 

Example of use 135 

Two, powers of 140 

Two's complement notation 24,137 



Unit check condition Ii5, 111 

Unit exception condition ...116,111 

Unit of information (the byte), basic 8 

Unit status conditions 

Attention 113,111 

Busy 114 

Channel end 115, 111 

Control unit end 114, 111, 112 

Device end 115, 111 

Status modifier 113 

Unit check US, 111 

Unit exception 116,111 

Universal instruction set 167,5 

Unnormahzed operation (in floating-point arithmetic) 42 

UNPACK instruction (UNPK) 

Description 39 

Example of use 136.4 

Unusual conditions that cause interruptions 16, 79 

USA standard code for information interchange extended 

to eight bits (USASCII-8) 250,12,36 



Tables 

Conversion 146, 147 

Hexadecimal 141 

Powers of two 140 

Teleprocessing, use of direct control and timer features in 5 
Termination and suppression of instructions by interruption 78 

Termination of I/O operations 20, 108 

Termination of instructions, possible differences among 

models in 162 

TEST AND SET instruction (TS) 

Description 74, 7 

Example of use 136.6 

TEST CHANNEL instruction (TCH) 98,19 

TEST I/O instruction (TIO) 95,19 

Test light on systeni control panel 124 

TEST UNDER MASK instruction (TM) 

Description 56 

Example of use 135 

TIC (Transfer in Channel) command 107,20,98 

Timer 

Address 15 

Description 17 

Interruption caused by 81, 16 

Possible differences among models in 163 

Transfer in Channel command 107,20,98 

Transfer of data, basic procedure for a 21 



Variable-length logical information 51 

Violation (exception), protection 79 



Wait and running program states 68, 17 

Wait light on system control panel 124 

Wait state bit (in PSW) 71,15 

Word 8 

Working (state of I/O system) 90 

Wraparound of register addresses in LOA0 MULTIPLE 

and STORE MULTIPLE .27,32 

Wraparound with maximum addressable main storage 8, 101 

Write command 105, 19; 98 

WRITE DIRECT instruction (WRD) 75 



ZERO AND ADD instruction (ZAP) 

Description 37 

Example of use 136.2 

Zone and sign codes used in decimal arithmetic 36 

Zone in zoned decimal data 35 

Zoned decimal number 35 



Index 175 



*#?i821-6 



mm 



International Business Machines Corporation 
Data Processing Division 
112 East Post Hoad, White Plains, NY. 10601 
[USA Only] 

IBM World Trade Corporation 

B21 United Nations Plaza, New York, New York 10017 

[International] 



READER'S COMMENT FORM 

IBM System/360 Principles of Operation 



A22-682mi^i^ 



Your comments, accompanied by answers to the following questions, help us produce better 
publications for your use. If your answer to a question is "No" or requires qualification, 
please explain in the space provided below. Comments and suggestions become the property of 

IBM. 





Yes 


No 


Does this publication meet your needs? 


D 


n 


Did you find the material: 






Easy to read and understand? 


D 


u 


Organized for convenient use? 


a 


n 


Complete? 


n 


n 


Well illustrated? 


n 


u 


Written for your technical level? 


a 


n 



)Jihat is your occupation?. 



• How do you use this publication? 

As an introduction to the subject? lH 

4 For advanced knowledge of the subject? lIJ 

For information about operating procedures? LJ 

Other , 



As an instructor in a class? LJ 
As a student in a class? Lj 
As a reference manual? LJ 



^Please give specific page and line references with your comments when appropriate. 
^ you wish a reply, be sure to include your name and address. 

COMMENTS: 



Thank you for your cooperation. No postage necessary if mailed in the U.S.A. 



VOUR COMMENTS PLEASE ... 

ThiSiyiL bulletin is c'le of a series which serves as reference sources for systems analysts, 
pro^jrammers and operators of IBM systems. Your answers to the questions on the back of 
this form, together with your comments, will help us produce better publications for your 
use. Each reply will be carefully reviewed by the persons responsible for writing and pub- 
lishing this material. All comments and suggestions become the property of IBM. 

Please note: Requests for copies of publications and for assistance in utilizing your IBM sys- 
tem should be directed to your IBM representative or to the IBM sales office serving your 
locality. 



fold 



fold 



FIRST CLASS 

PERMIT NO. 419 

POUGHKEEPSIE, N.Y. 



BUSINESS REPLY MAIL 

NO POSTAGE NECESSARY IF MAILED IN THE UNITEQ STATES 



POSTAGE WILL BE PAID BY . . . 

IBM CORPORATION 

P.O. BOX 390 
POUGHKEEPSIE, N.Y. 12602 



ATTENTION: CUSTOMER MANUALS , DEPT. B98 




fold 



e; 



International Business Machines Corporation 
Data Processing Division 
112 East Post Road, Whits Plains, N.Y 10601 
[USA Only] 

IBM World Trade Corporation 

821 United Nations Plaza, New York, New YorklOQl? 

[International] 



